![]() |
Exiv2
|
Interface for a standard TIFF IFD entry consisting of a value which is a set of offsets to a data area. The sizes of these "strips" are provided in a related TiffSizeEntry, tag and group of which are set in the constructor. The implementations of this interface differ in whether the data areas are extracted to the higher level metadata (TiffDataEntry) or not (TiffImageEntry). More...
#include <tiffcomposite_int.hpp>
Public Member Functions | |
Creators | |
TiffDataEntryBase (uint16_t tag, IfdId group, uint16_t szTag, IfdId szGroup) | |
Constructor. | |
Manipulators | |
virtual void | setStrips (const Value *pSize, const byte *pData, size_t sizeData, size_t baseOffset)=0 |
Set the data areas ("strips"). | |
![]() | |
constexpr | TiffEntryBase (uint16_t tag, IfdId group, TiffType tiffType=ttUndefined) |
Default constructor. | |
~TiffEntryBase () override=default | |
Virtual destructor. | |
TiffEntryBase & | operator= (const TiffEntryBase &)=delete |
Assignment operator. | |
void | encode (TiffEncoder &encoder, const Exifdatum *datum) |
Encode a TIFF component from the metadatum provided and information from the encoder as needed. | |
void | setOffset (size_t offset) |
Set the offset. | |
void | setData (byte *pData, size_t size, std::shared_ptr< DataBuf > storage) |
Set pointer and size of the entry's data (not taking ownership of the data). | |
void | setData (std::shared_ptr< DataBuf > buf) |
Set the entry's data buffer. A shared_ptr is used to manage the DataBuf because TiffEntryBase has a clone method so it is possible (in theory) for the DataBuf to have multiple owners. | |
void | updateValue (Value::UniquePtr value, ByteOrder byteOrder) |
Update the value. Takes ownership of the pointer passed in. | |
void | setValue (Value::UniquePtr value) |
Set tag value. Takes ownership of the pointer passed in. | |
TiffType | tiffType () const |
Return the TIFF type. | |
size_t | offset () const |
Return the offset to the data area relative to the base for the component (usually the start of the TIFF header) | |
int | idx () const override |
Return the unique id of the entry in the image. | |
const byte * | pData () const |
Return a pointer to the binary representation of the value of this component. | |
const Value * | pValue () const |
Return a const pointer to the converted value of this component. | |
![]() | |
constexpr | TiffComponent (uint16_t tag, IfdId group) |
Constructor. | |
virtual | ~TiffComponent ()=default |
Virtual destructor. | |
TiffComponent (const TiffComponent &)=default | |
TiffComponent & | operator= (const TiffComponent &)=default |
TiffComponent * | addPath (uint16_t tag, TiffPath &tiffPath, TiffComponent *pRoot, UniquePtr object=nullptr) |
Add a TIFF entry tag to the component. Components on the path to the entry are added if they don't exist yet. | |
TiffComponent * | addChild (UniquePtr tiffComponent) |
Add a child to the component. Default is to do nothing. | |
TiffComponent * | addNext (UniquePtr tiffComponent) |
Add a "next" component to the component. Default is to do nothing. | |
void | accept (TiffVisitor &visitor) |
Interface to accept visitors (Visitor pattern). Visitors can perform operations on all components of the composite. | |
void | setStart (const byte *pStart) |
Set a pointer to the start of the binary representation of the component in a memory buffer. The buffer must be allocated and freed outside of this class. | |
size_t | write (IoWrapper &ioWrapper, ByteOrder byteOrder, size_t offset, size_t valueIdx, size_t dataIdx, size_t &imageIdx) |
Write a TiffComponent to a binary image. | |
uint16_t | tag () const |
Return the tag of this entry. | |
IfdId | group () const |
Return the group id of this component. | |
byte * | start () const |
Return a pointer to the start of the binary representation of the component. | |
UniquePtr | clone () const |
Return an auto-pointer to a copy of itself (deep copy, but without any children). The caller owns this copy and the auto-pointer ensures that it will be deleted. | |
size_t | writeData (IoWrapper &ioWrapper, ByteOrder byteOrder, size_t offset, size_t dataIdx, size_t &imageIdx) const |
Write the IFD data of this component to a binary image. Return the number of bytes written. Components derived from TiffEntryBase implement this method if needed. | |
size_t | writeImage (IoWrapper &ioWrapper, ByteOrder byteOrder) const |
Write the image data of this component to a binary image. Return the number of bytes written. TIFF components implement this method if needed. | |
size_t | size () const |
Return the size in bytes of the IFD value of this component when written to a binary image. | |
size_t | count () const |
Return the number of components in this component. | |
size_t | sizeData () const |
Return the size in bytes of the IFD data of this component when written to a binary image. This is a support function for write(). Components derived from TiffEntryBase implement this method corresponding to their implementation of writeData(). | |
size_t | sizeImage () const |
Return the size in bytes of the image data of this component when written to a binary image. This is a support function for write(). TIFF components implement this method corresponding to their implementation of writeImage(). | |
Accessors | |
uint16_t | szTag () const |
Return the group of the entry which has the size. | |
IfdId | szGroup () const |
Return the group of the entry which has the size. | |
Additional Inherited Members | |
![]() | |
using | UniquePtr = std::unique_ptr< TiffComponent > |
TiffComponent auto_ptr type. | |
using | Components = std::vector< UniquePtr > |
Container type to hold all metadata. | |
![]() | |
TiffEntryBase (const TiffEntryBase &rhs) | |
Copy constructor (used to implement clone()). | |
virtual void | doEncode (TiffEncoder &encoder, const Exifdatum *datum)=0 |
Implements encode(). | |
void | setCount (size_t count) |
Set the number of components in this entry. | |
void | setIdx (int idx) |
Set the unique id of the entry in the image. | |
size_t | doWrite (IoWrapper &ioWrapper, ByteOrder byteOrder, size_t offset, size_t valueIdx, size_t dataIdx, size_t &imageIdx) override |
Implements write(). Write the value of a standard TIFF entry to the ioWrapper, return the number of bytes written. Only the ioWrapper and byteOrder arguments are used. | |
size_t | doCount () const override |
Implements count(). | |
size_t | doWriteData (IoWrapper &ioWrapper, ByteOrder byteOrder, size_t offset, size_t dataIdx, size_t &imageIdx) const override |
Implements writeData(). Standard TIFF entries have no data: write nothing and return 0. | |
size_t | doWriteImage (IoWrapper &ioWrapper, ByteOrder byteOrder) const override |
Implements writeImage(). Standard TIFF entries have no image data: write nothing and return 0. | |
size_t | doSize () const override |
Implements size(). Return the size of a standard TIFF entry. | |
size_t | doSizeData () const override |
Implements sizeData(). Return 0. | |
size_t | doSizeImage () const override |
Implements sizeImage(). Return 0. | |
std::shared_ptr< DataBuf > | storage () const |
Used (internally) to create another reference to the DataBuf reference by storage_. | |
![]() | |
virtual TiffComponent * | doAddPath (uint16_t tag, TiffPath &tiffPath, TiffComponent *pRoot, TiffComponent::UniquePtr object) |
Implements addPath(). The default implementation does nothing. | |
virtual TiffComponent * | doAddChild (UniquePtr tiffComponent) |
Implements addChild(). The default implementation does nothing. | |
virtual TiffComponent * | doAddNext (UniquePtr tiffComponent) |
Implements addNext(). The default implementation does nothing. | |
virtual void | doAccept (TiffVisitor &visitor)=0 |
Implements accept(). | |
virtual TiffComponent * | doClone () const =0 |
Internal virtual copy constructor, implements clone(). | |
![]() | |
static size_t | writeOffset (byte *buf, size_t offset, TiffType tiffType, ByteOrder byteOrder) |
Helper function to write an offset to a preallocated binary buffer. | |
Interface for a standard TIFF IFD entry consisting of a value which is a set of offsets to a data area. The sizes of these "strips" are provided in a related TiffSizeEntry, tag and group of which are set in the constructor. The implementations of this interface differ in whether the data areas are extracted to the higher level metadata (TiffDataEntry) or not (TiffImageEntry).
|
pure virtual |
Set the data areas ("strips").
pSize | Pointer to the Value holding the sizes corresponding to this data entry. |
pData | Pointer to the data area. |
sizeData | Size of the data area. |
baseOffset | Base offset into the data area. |
Implemented in Exiv2::Internal::TiffDataEntry, and Exiv2::Internal::TiffImageEntry.
Referenced by Exiv2::Internal::TiffReader::visitSizeEntry().