#include <exiv2/exiv2.hpp>
#include <iostream>
#include <iomanip>
#include <cassert>
int main(int argc, char* const argv[])
try {
#ifdef EXV_ENABLE_BMFF
Exiv2::enableBMFF();
#endif
if (argc != 2) {
std::cout << "Usage: " << argv[0] << " file\n";
return 1;
}
assert (image.get() != 0);
image->readMetadata();
std::string error(argv[1]);
error += ": No IPTC data found in the file";
}
std::cout << std::setw(44) << std::setfill(' ') << std::left
<< md->key() << " "
<< "0x" << std::setw(4) << std::setfill('0') << std::right
<< std::hex << md->tag() << " "
<< std::setw(9) << std::setfill(' ') << std::left
<< md->typeName() << " "
<< std::dec << std::setw(3)
<< std::setfill(' ') << std::right
<< md->count() << " "
<< std::dec << md->value()
<< std::endl;
}
return 0;
}
std::cout << "Caught Exiv2 exception '" << e << "'\n";
return -1;
}
Error class interface. Allows the definition and use of a hierarchy of error classes which can all be...
Definition: error.hpp:174
static Image::AutoPtr open(const std::string &path, bool useCurl=true)
Create an Image subclass of the appropriate type by reading the specified file. Image type is derived...
Definition: image.cpp:922
std::auto_ptr< Image > AutoPtr
Image auto_ptr type.
Definition: image.hpp:81
A container for IPTC data. This is a top-level class of the Exiv2 library.
Definition: iptc.hpp:170
iterator begin()
Begin of the metadata.
Definition: iptc.hpp:221
IptcMetadata::iterator iterator
IptcMetadata iterator type.
Definition: iptc.hpp:173
bool empty() const
Return true if there is no IPTC metadata.
Definition: iptc.hpp:255
iterator end()
End of the metadata.
Definition: iptc.hpp:223
static bool initialize(XmpParser::XmpLockFct xmpLockFct=0, void *pLockData=0)
Initialize the XMP Toolkit.
Definition: xmp.cpp:641
static void terminate()
Terminate the XMP Toolkit and unregister custom namespaces.
Definition: xmp.cpp:703
BasicError< char > Error
Error class used for exceptions (std::string based)
Definition: error.hpp:324