// ***************************************************************** -*- C++ -*- /* * Copyright (C) 2006 Andreas Huggel * * This program is part of the Exiv2 distribution. * * This program is free software; you can redistribute it and/or * modify it under the terms of the GNU General Public License * as published by the Free Software Foundation; either version 2 * of the License, or (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 51 Franklin Street, 5th Floor, Boston, MA 02110-1301 USA. */ /* File: sigmamn2.cpp Version: $Rev$ Author(s): Andreas Huggel (ahu) History: 18-Apr-06, ahu: created */ // ***************************************************************************** #include "rcsid.hpp" EXIV2_RCSID("@(#) $Id$"); // ***************************************************************************** // included header files #ifdef _MSC_VER # include "exv_msvc.h" #else # include "exv_conf.h" #endif #include "sigmamn2.hpp" #include "tiffcomposite.hpp" #include "types.hpp" // + standard includes // ***************************************************************************** // class member definitions namespace Exiv2 { const byte SigmaMnHeader::signature1_[] = { 'S', 'I', 'G', 'M', 'A', '\0', '\0', '\0', 0x01, 0x00 }; const byte SigmaMnHeader::signature2_[] = { 'F', 'O', 'V', 'E', 'O', 'N', '\0', '\0', 0x01, 0x00 }; const uint32_t SigmaMnHeader::size_ = 10; SigmaMnHeader::SigmaMnHeader() { read(signature1_, size_, invalidByteOrder); } bool SigmaMnHeader::read(const byte* pData, uint32_t size, ByteOrder /*byteOrder*/) { assert (pData != 0); if (size < size_) return false; if ( 0 != memcmp(pData, signature1_, 8) && 0 != memcmp(pData, signature2_, 8)) return false; buf_.alloc(size_); memcpy(buf_.pData_, pData, buf_.size_); start_ = size_; return true; } // SigmaMnHeader::read bool TiffSigmaMn::doReadHeader(const byte* pData, uint32_t size, ByteOrder byteOrder) { return header_.read(pData, size, byteOrder); } uint32_t TiffSigmaMn::doIfdOffset() const { return header_.ifdOffset(); } // ************************************************************************* // free functions TiffComponent* newSigmaMn(uint16_t tag, uint16_t group, uint16_t mnGroup, const byte* /*pData*/, uint32_t /*size*/, ByteOrder /*byteOrder*/) { return new TiffSigmaMn(tag, group, mnGroup); } } // namespace Exiv2