Sample program to print Exif data from an image.
#include <exiv2/exiv2.hpp>
#include <iostream>
#include <regex>
while (pList->
tag_ != 0xffff && pList->
tag_ != tag)
pList++;
return pList->
tag_ != 0xffff ? pList :
nullptr;
}
int main(int argc, char* const argv[]) {
try {
setlocale(LC_CTYPE, ".utf8");
const char* prog = argv[0];
if (argc == 1) {
std::cout << "Usage: " << prog << " [ [--lint] path | --version | --version-test ]" << std::endl;
return EXIT_FAILURE;
}
int rc = EXIT_SUCCESS;
const char* file = argv[1];
bool bLint = strcmp(file, "--lint") == 0 && argc == 3;
if (bLint)
file = argv[2];
if (strcmp(file, "--version") == 0) {
std::vector<std::regex> keys;
return rc;
}
if (strcmp(file, "--version-test") == 0) {
std::cout << "EXV_PACKAGE_VERSION " << EXV_PACKAGE_VERSION << std::endl
<<
"strlen(Exiv2::version()) " << ::strlen(
Exiv2::version()) << std::endl
#if EXIV2_TEST_VERSION(0, 15, 0)
std::cout << "Available Exiv2 version is equal to or greater than 0.13\n";
} else {
std::cout << "Installed Exiv2 version is less than 0.13\n";
}
#else
std::cout << "Compile-time Exiv2 version doesn't have Exiv2::testVersion()\n";
#endif
return rc;
}
image->readMetadata();
std::string error("No Exif data found in file");
throw Exiv2::Error(Exiv2::ErrorCode::kerErrorMessage, error);
}
std::set<std::string> shortLong;
shortLong.insert("Exif.Photo.PixelXDimension");
shortLong.insert("Exif.Photo.PixelYDimension");
shortLong.insert("Exif.Photo.ImageLength");
shortLong.insert("Exif.Photo.ImageWidth");
shortLong.insert("Exif.Photo.RowsPerStrip");
shortLong.insert("Exif.Photo.StripOffsets");
shortLong.insert("Exif.Photo.StripByteCounts");
auto end = exifData.
end();
for (
auto i = exifData.
begin(); i != end; ++i) {
if (!bLint) {
const char* tn = i->typeName();
std::cout << std::setw(44) << std::setfill(' ') << std::left << i->key() << " "
<< "0x" << std::setw(4) << std::setfill('0') << std::right << std::hex << i->tag() << " "
<< std::setw(9) << std::setfill(' ') << std::left << (tn ? tn : "Unknown") << " " << std::dec
<< std::setw(3) << std::setfill(' ') << std::right << i->count() << " " << std::dec << i->toString()
<< "\n";
} else {
if (tagInfo) {
&& (shortLong.find(i->key()) == shortLong.end() ||
) {
std::cerr << i->key() << " type " << i->typeName() << " (" << type << ")"
<< std::endl;
rc = 2;
}
}
}
}
return rc;
std::cout <<
"Caught Exiv2 exception '" << e.
what() <<
"'\n";
return EXIT_FAILURE;
}
}
Simple error class used for exceptions. An output operator is provided to print errors to a stream.
Definition: error.hpp:235
const char * what() const noexcept override
Return the error message as a C-string. The pointer returned by what() is valid only as long as the B...
A container for Exif data. This is a top-level class of the Exiv2 library. The container holds Exifda...
Definition: exif.hpp:379
bool empty() const
Return true if there is no Exif metadata.
Definition: exif.hpp:465
iterator begin()
Begin of the metadata.
Definition: exif.hpp:435
iterator end()
End of the metadata.
Definition: exif.hpp:439
static Image::UniquePtr 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...
static const char * typeName(TypeId typeId)
Return the name of the type, 0 if unknown.
static void terminate()
Terminate the XMP Toolkit and unregister custom namespaces.
static bool initialize(XmpParser::XmpLockFct xmpLockFct=nullptr, void *pLockData=nullptr)
Initialize the XMP Toolkit.
EXIV2API bool testVersion(uint32_t major, uint32_t minor, uint32_t patch)
Test the version of the available Exiv2 library at runtime. Return true if it is the same as or newer...
EXIV2API void dumpLibraryInfo(std::ostream &os, const std::vector< std::regex > &keys)
dumpLibraryInfo implements the exiv2 option –version –verbose used by exiv2 test suite to inspect lib...
TypeId
Exiv2 value type identifiers.
Definition: types.hpp:70
@ unsignedShort
Exif SHORT type, 16-bit (2-byte) unsigned integer.
Definition: types.hpp:73
@ unsignedLong
Exif LONG type, 32-bit (4-byte) unsigned integer.
Definition: types.hpp:74
@ comment
Exiv2 type for the Exif user comment.
Definition: types.hpp:90
@ undefined
Exif UNDEFINED type, an 8-bit byte that may contain anything.
Definition: types.hpp:77
EXIV2API std::string versionNumberHexString()
Return the version of Exiv2 as hex string of fixed length 6.
EXIV2API const char * version()
Return the version of Exiv2 as "C" string eg "0.27.0.2".
EXIV2API uint32_t versionNumber()
Return the version of Exiv2 available at runtime as a uint32_t.
EXIV2API std::string versionString()
Return the version string Example: "0.25.0" (major.minor.patch)
Tag information.
Definition: tags.hpp:224
uint16_t tag_
Tag.
Definition: tags.hpp:225
TypeId typeId_
Type id.
Definition: tags.hpp:231