Blame lib/peffile.cpp

rpm-build d2b433
/*
rpm-build d2b433
 * libopenraw - peffile.cpp
rpm-build d2b433
 *
rpm-build d2b433
 * Copyright (C) 2006-2017 Hubert Figuiere
rpm-build d2b433
 *
rpm-build d2b433
 * This library is free software: you can redistribute it and/or
rpm-build d2b433
 * modify it under the terms of the GNU Lesser General Public License
rpm-build d2b433
 * as published by the Free Software Foundation, either version 3 of
rpm-build d2b433
 * the License, or (at your option) any later version.
rpm-build d2b433
 *
rpm-build d2b433
 * This library is distributed in the hope that it will be useful,
rpm-build d2b433
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
rpm-build d2b433
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
rpm-build d2b433
 * Lesser General Public License for more details.
rpm-build d2b433
 *
rpm-build d2b433
 * You should have received a copy of the GNU Lesser General Public
rpm-build d2b433
 * License along with this library.  If not, see
rpm-build d2b433
 * <http://www.gnu.org/licenses/>.
rpm-build d2b433
 */
rpm-build d2b433
rpm-build d2b433
rpm-build d2b433
#include <libopenraw/cameraids.h>
rpm-build d2b433
rpm-build d2b433
#include "rawdata.hpp"
rpm-build d2b433
#include "ifd.hpp"
rpm-build d2b433
#include "ifdfilecontainer.hpp"
rpm-build d2b433
#include "ifddir.hpp"
rpm-build d2b433
#include "peffile.hpp"
rpm-build d2b433
#include "rawfile_private.hpp"
rpm-build d2b433
rpm-build d2b433
using namespace Debug;
rpm-build d2b433
rpm-build d2b433
namespace OpenRaw {
rpm-build d2b433
namespace Internals {
rpm-build d2b433
rpm-build d2b433
#define OR_MAKE_PENTAX_TYPEID(camid) \
rpm-build d2b433
    OR_MAKE_FILE_TYPEID(OR_TYPEID_VENDOR_PENTAX,camid)
rpm-build d2b433
rpm-build d2b433
/* taken from dcraw, by default */
rpm-build d2b433
static const BuiltinColourMatrix s_matrices[] = {
rpm-build d2b433
    { OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_IST_D_PEF),
rpm-build d2b433
      0,
rpm-build d2b433
      0,
rpm-build d2b433
      { 9651, -2059, -1189, -8881, 16512, 2487, -1460, 1345, 10687 } },
rpm-build d2b433
    { OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_IST_DL_PEF),
rpm-build d2b433
      0,
rpm-build d2b433
      0,
rpm-build d2b433
      { 10829, -2838, -1115, -8339, 15817, 2696, -837, 680, 11939 } },
rpm-build d2b433
    { OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_IST_DS_PEF),
rpm-build d2b433
      0,
rpm-build d2b433
      0,
rpm-build d2b433
      { 10371, -2333, -1206, -8688, 16231, 2602, -1230, 1116, 11282 } },
rpm-build d2b433
    { OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_K10D_PEF),
rpm-build d2b433
      0,
rpm-build d2b433
      0,
rpm-build d2b433
      { 9566, -2863, -803, -7170, 15172, 2112, -818, 803, 9705 } },
rpm-build d2b433
    { OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_K1_PEF),
rpm-build d2b433
      0,
rpm-build d2b433
      0,
rpm-build d2b433
      { 8566, -2746, -1201, -3612, 12204, 1550, -893, 1680, 6264 } },
rpm-build d2b433
    { OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_K100D_PEF),
rpm-build d2b433
      0,
rpm-build d2b433
      0,
rpm-build d2b433
      { 11095, -3157, -1324, -8377, 15834, 2720, -1108, 947, 11688 } },
rpm-build d2b433
    { OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_K100D_PEF),
rpm-build d2b433
      0,
rpm-build d2b433
      0,
rpm-build d2b433
      { 11095, -3157, -1324, -8377, 15834, 2720, -1108, 947, 11688 } },
rpm-build d2b433
    { OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_K20D_PEF),
rpm-build d2b433
      0,
rpm-build d2b433
      0,
rpm-build d2b433
      { 9427, -2714, -868, -7493, 16092, 1373, -2199, 3264, 7180 } },
rpm-build d2b433
    { OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_K200D_PEF),
rpm-build d2b433
      0,
rpm-build d2b433
      0,
rpm-build d2b433
      { 9186, -2678, -907, -8693, 16517, 2260, -1129, 1094, 8524 } },
rpm-build d2b433
    { OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_KR_PEF),
rpm-build d2b433
      0,
rpm-build d2b433
      0,
rpm-build d2b433
      { 9895, -3077, -850, -5304, 13035, 2521, -883, 1768, 6936 } },
rpm-build d2b433
    { OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_K5_PEF),
rpm-build d2b433
      0,
rpm-build d2b433
      0,
rpm-build d2b433
      { 8713, -2833, -743, -4342, 11900, 2772, -722, 1543, 6247 } },
rpm-build d2b433
    { OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_K5_IIS_PEF),
rpm-build d2b433
      0,
rpm-build d2b433
      0,
rpm-build d2b433
      { 8170, -2725, -639, -4440, 12017, 2744, -771, 1465, 6599 } },
rpm-build d2b433
    { OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_K7_PEF),
rpm-build d2b433
      0,
rpm-build d2b433
      0,
rpm-build d2b433
      { 9142, -2947, -678, -8648, 16967, 1663, -2224, 2898, 8615 } },
rpm-build d2b433
    { OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_KX_PEF),
rpm-build d2b433
      0,
rpm-build d2b433
      0,
rpm-build d2b433
      { 8843, -2837, -625, -5025, 12644, 2668, -411, 1234, 7410 } },
rpm-build d2b433
    { OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_KS2_PEF),
rpm-build d2b433
      0,
rpm-build d2b433
      0,
rpm-build d2b433
      { 8662, -3280, -798, -3928, 11771, 2444, -586, 1232, 6054 } },
rpm-build d2b433
    { OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_645D_PEF),
rpm-build d2b433
      0,
rpm-build d2b433
      0x3e00,
rpm-build d2b433
      { 10646, -3593, -1158, -3329, 11699, 1831, -667, 2874, 6287 } },
rpm-build d2b433
rpm-build d2b433
    { 0, 0, 0, { 0, 0, 0, 0, 0, 0, 0, 0, 0 } }
rpm-build d2b433
};
rpm-build d2b433
rpm-build d2b433
const struct IfdFile::camera_ids_t PEFFile::s_def[] = {
rpm-build d2b433
    { "PENTAX *ist D      ", OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_IST_D_PEF) },
rpm-build d2b433
    { "PENTAX *ist DL     ", OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_IST_DL_PEF) },
rpm-build d2b433
    { "PENTAX *ist DS     ", OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_IST_DS_PEF) },
rpm-build d2b433
    { "PENTAX K10D        ", OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_K10D_PEF) },
rpm-build d2b433
    { "PENTAX K100D       ", OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_K100D_PEF) },
rpm-build d2b433
    { "PENTAX K100D Super ", OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_K100D_PEF) },
rpm-build d2b433
    { "PENTAX K20D        ", OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_K20D_PEF) },
rpm-build d2b433
    { "PENTAX K200D       ", OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_K200D_PEF) },
rpm-build d2b433
    { "PENTAX K-1         ", OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_K1_PEF) },
rpm-build d2b433
    { "PENTAX K-r         ", OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_KR_PEF) },
rpm-build d2b433
    { "PENTAX K-5         ", OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_K5_PEF) },
rpm-build d2b433
    { "PENTAX K-5 II s    ", OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_K5_IIS_PEF) },
rpm-build d2b433
    { "PENTAX K-7         ", OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_K7_PEF) },
rpm-build d2b433
    { "PENTAX K-70        ", OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_K70_PEF) },
rpm-build d2b433
    { "PENTAX K-S2        ", OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_KS2_PEF) },
rpm-build d2b433
    { "PENTAX K-x         ", OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_KX_PEF) },
rpm-build d2b433
    { "PENTAX 645D        ", OR_MAKE_PENTAX_TYPEID(OR_TYPEID_PENTAX_645D_PEF) },
rpm-build d2b433
    { 0, 0 }
rpm-build d2b433
};
rpm-build d2b433
rpm-build d2b433
rpm-build d2b433
RawFile *PEFFile::factory(const IO::Stream::Ptr &s)
rpm-build d2b433
{
rpm-build d2b433
    return new PEFFile(s);
rpm-build d2b433
}
rpm-build d2b433
rpm-build d2b433
PEFFile::PEFFile(const IO::Stream::Ptr &s)
rpm-build d2b433
    : IfdFile(s, OR_RAWFILE_TYPE_PEF)
rpm-build d2b433
{
rpm-build d2b433
    _setIdMap(s_def);
rpm-build d2b433
    _setMatrices(s_matrices);
rpm-build d2b433
}
rpm-build d2b433
rpm-build d2b433
PEFFile::~PEFFile()
rpm-build d2b433
{
rpm-build d2b433
}
rpm-build d2b433
rpm-build d2b433
IfdDir::Ref  PEFFile::_locateCfaIfd()
rpm-build d2b433
{
rpm-build d2b433
    // in PEF the CFA IFD is the main IFD
rpm-build d2b433
    return mainIfd();
rpm-build d2b433
}
rpm-build d2b433
rpm-build d2b433
IfdDir::Ref  PEFFile::_locateMainIfd()
rpm-build d2b433
{
rpm-build d2b433
    return m_container->setDirectory(0);
rpm-build d2b433
}
rpm-build d2b433
rpm-build d2b433
::or_error PEFFile::_getRawData(RawData & data, uint32_t options)
rpm-build d2b433
{
rpm-build d2b433
    ::or_error err;
rpm-build d2b433
    const IfdDir::Ref & _cfaIfd = cfaIfd();
rpm-build d2b433
    err = _getRawDataFromDir(data, _cfaIfd);
rpm-build d2b433
    if(err == OR_ERROR_NONE) {
rpm-build d2b433
        uint16_t compression = data.compression();
rpm-build d2b433
        switch(compression) {
rpm-build d2b433
        case IFD::COMPRESS_CUSTOM:
rpm-build d2b433
            if((options & OR_OPTIONS_DONT_DECOMPRESS) == 0) {
rpm-build d2b433
                // TODO decompress
rpm-build d2b433
            }
rpm-build d2b433
            break;
rpm-build d2b433
        default:
rpm-build d2b433
            break;
rpm-build d2b433
        }
rpm-build d2b433
    }
rpm-build d2b433
    return err;
rpm-build d2b433
}
rpm-build d2b433
rpm-build d2b433
}
rpm-build d2b433
}
rpm-build d2b433
/*
rpm-build d2b433
  Local Variables:
rpm-build d2b433
  mode:c++
rpm-build d2b433
  c-file-style:"stroustrup"
rpm-build d2b433
  c-file-offsets:((innamespace . 0))
rpm-build d2b433
  indent-tabs-mode:nil
rpm-build d2b433
  fill-column:80
rpm-build d2b433
  End:
rpm-build d2b433
*/
rpm-build d2b433