|
Packit |
01d647 |
#include "cr2header_int.hpp"
|
|
Packit |
01d647 |
|
|
Packit |
01d647 |
namespace Exiv2 {
|
|
Packit |
01d647 |
namespace Internal {
|
|
Packit |
01d647 |
|
|
Packit |
01d647 |
const char* Cr2Header::cr2sig_ = "CR\2\0";
|
|
Packit |
01d647 |
|
|
Packit |
01d647 |
Cr2Header::Cr2Header(ByteOrder byteOrder)
|
|
Packit |
01d647 |
: TiffHeaderBase(42, 16, byteOrder, 0x00000010),
|
|
Packit |
01d647 |
offset2_(0x00000000)
|
|
Packit |
01d647 |
{
|
|
Packit |
01d647 |
}
|
|
Packit |
01d647 |
|
|
Packit |
01d647 |
Cr2Header::~Cr2Header()
|
|
Packit |
01d647 |
{
|
|
Packit |
01d647 |
}
|
|
Packit |
01d647 |
|
|
Packit |
01d647 |
bool Cr2Header::read(const byte* pData, uint32_t size)
|
|
Packit |
01d647 |
{
|
|
Packit |
01d647 |
if (!pData || size < 16) {
|
|
Packit |
01d647 |
return false;
|
|
Packit |
01d647 |
}
|
|
Packit |
01d647 |
|
|
Packit |
01d647 |
if (pData[0] == 'I' && pData[0] == pData[1]) {
|
|
Packit |
01d647 |
setByteOrder(littleEndian);
|
|
Packit |
01d647 |
}
|
|
Packit |
01d647 |
else if (pData[0] == 'M' && pData[0] == pData[1]) {
|
|
Packit |
01d647 |
setByteOrder(bigEndian);
|
|
Packit |
01d647 |
}
|
|
Packit |
01d647 |
else {
|
|
Packit |
01d647 |
return false;
|
|
Packit |
01d647 |
}
|
|
Packit |
01d647 |
if (tag() != getUShort(pData + 2, byteOrder())) return false;
|
|
Packit |
01d647 |
setOffset(getULong(pData + 4, byteOrder()));
|
|
Packit |
01d647 |
if (0 != memcmp(pData + 8, cr2sig_, 4)) return false;
|
|
Packit |
01d647 |
offset2_ = getULong(pData + 12, byteOrder());
|
|
Packit |
01d647 |
|
|
Packit |
01d647 |
return true;
|
|
Packit |
01d647 |
} // Cr2Header::read
|
|
Packit |
01d647 |
|
|
Packit |
01d647 |
DataBuf Cr2Header::write() const
|
|
Packit |
01d647 |
{
|
|
Packit |
01d647 |
DataBuf buf(16);
|
|
Packit |
01d647 |
switch (byteOrder()) {
|
|
Packit |
01d647 |
case littleEndian:
|
|
Packit |
01d647 |
buf.pData_[0] = 'I';
|
|
Packit |
01d647 |
break;
|
|
Packit |
01d647 |
case bigEndian:
|
|
Packit |
01d647 |
buf.pData_[0] = 'M';
|
|
Packit |
01d647 |
break;
|
|
Packit |
01d647 |
case invalidByteOrder:
|
|
Packit |
01d647 |
assert(false);
|
|
Packit |
01d647 |
break;
|
|
Packit |
01d647 |
}
|
|
Packit |
01d647 |
buf.pData_[1] = buf.pData_[0];
|
|
Packit |
01d647 |
|
|
Packit |
01d647 |
us2Data(buf.pData_ + 2, tag(), byteOrder());
|
|
Packit |
01d647 |
ul2Data(buf.pData_ + 4, 0x00000010, byteOrder());
|
|
Packit |
01d647 |
memcpy(buf.pData_ + 8, cr2sig_, 4);
|
|
Packit |
01d647 |
// Write a dummy value for the RAW IFD offset. The offset-writer is used to set this offset in a second pass.
|
|
Packit |
01d647 |
ul2Data(buf.pData_ + 12, 0x00000000, byteOrder());
|
|
Packit |
01d647 |
return buf;
|
|
Packit |
01d647 |
} // Cr2Header::write
|
|
Packit |
01d647 |
|
|
Packit |
01d647 |
bool Cr2Header::isImageTag(uint16_t tag, IfdId group, const PrimaryGroups* /*pPrimaryGroups*/) const
|
|
Packit |
01d647 |
{
|
|
Packit |
01d647 |
// CR2 image tags are all IFD2 and IFD3 tags
|
|
Packit |
01d647 |
if (group == ifd2Id || group == ifd3Id) return true;
|
|
Packit |
01d647 |
// ...and any (IFD0) tag that is in the TIFF image tags list
|
|
Packit |
01d647 |
return isTiffImageTag(tag, group);
|
|
Packit |
01d647 |
}
|
|
Packit |
01d647 |
|
|
Packit |
01d647 |
}} // namespace Internal, Exiv2
|