Blame samples/largeiptc-test.cpp

Packit 01d647
// ***************************************************************** -*- C++ -*-
Packit 01d647
// Test for large (>65535 bytes) IPTC buffer
Packit 01d647
Packit 01d647
#include <exiv2/exiv2.hpp>
Packit 01d647
Packit 01d647
#include <iostream>
Packit 01d647
#include <cassert>
Packit 01d647
Packit 01d647
int main(int argc, char* const argv[])
Packit 01d647
try {
Packit 01d647
    if (argc != 3) {
Packit 01d647
        std::cout << "Usage: " << argv[0] << " image datafile\n";
Packit 01d647
        return 1;
Packit 01d647
    }
Packit 01d647
    std::string file(argv[1]);
Packit 01d647
    std::string data(argv[2]);
Packit 01d647
Packit 01d647
    // Read data file into data buffer
Packit 01d647
    Exiv2::FileIo io(data);
Packit 01d647
    if (io.open() != 0) {
Packit 01d647
      throw Exiv2::Error(Exiv2::kerDataSourceOpenFailed, io.path(), Exiv2::strError());
Packit 01d647
    }
Packit 01d647
    Exiv2::DataBuf buf((long)io.size());
Packit 01d647
    std::cout << "Reading " << buf.size_ << " bytes from " << data << "\n";
Packit 01d647
    io.read(buf.pData_, buf.size_);
Packit 01d647
    if (io.error() || !io.eof()) throw Exiv2::Error(Exiv2::kerFailedToReadImageData);
Packit 01d647
Packit 01d647
    // Read metadata from file
Packit 01d647
    Exiv2::Image::AutoPtr image = Exiv2::ImageFactory::open(file);
Packit 01d647
    assert(image.get() != 0);
Packit 01d647
    image->readMetadata();
Packit 01d647
Packit 01d647
    // Set Preview field to the content of the data file
Packit 01d647
    Exiv2::DataValue value;
Packit 01d647
    value.read(buf.pData_, buf.size_);
Packit 01d647
    Exiv2::IptcData& iptcData = image->iptcData();
Packit 01d647
    std::cout << "IPTC fields: " << iptcData.size() << "\n";
Packit 01d647
    iptcData["Iptc.Application2.Preview"] = value;
Packit 01d647
    std::cout << "IPTC fields: " << iptcData.size() << "\n";
Packit 01d647
Packit 01d647
    // Set IRB, compare with IPTC raw data
Packit 01d647
    Exiv2::DataBuf irb = Exiv2::Photoshop::setIptcIrb(0, 0, iptcData);
Packit 01d647
    std::cout << "IRB buffer : " << irb.size_ << "\n";
Packit 01d647
    const Exiv2::byte* record;
Packit 01d647
    uint32_t sizeHdr;
Packit 01d647
    uint32_t sizeData;
Packit 01d647
    Exiv2::Photoshop::locateIptcIrb(irb.pData_, irb.size_, &record, &sizeHdr, &sizeData);
Packit 01d647
    Exiv2::DataBuf rawIptc = Exiv2::IptcParser::encode(iptcData);
Packit 01d647
    std::cout << "Comparing IPTC and IRB size... ";
Packit 01d647
    if (static_cast<uint32_t>(rawIptc.size_) != sizeData) {
Packit 01d647
        std::cout << "not ";
Packit 01d647
    }
Packit 01d647
    std::cout << "ok\n";
Packit 01d647
Packit 01d647
    std::cout << "Comparing IPTC and IRB data... ";
Packit 01d647
    if (0 != memcmp(rawIptc.pData_, record + sizeHdr, sizeData)) {
Packit 01d647
        std::cout << "not ";
Packit 01d647
    }
Packit 01d647
    std::cout << "ok\n";
Packit 01d647
Packit 01d647
    // Set Iptc data and write it to the file
Packit 01d647
    image->writeMetadata();
Packit 01d647
Packit 01d647
    return 0;
Packit 01d647
}
Packit 01d647
catch (Exiv2::AnyError& e) {
Packit 01d647
    std::cout << "Caught Exiv2 exception '" << e << "'\n";
Packit 01d647
    return -1;
Packit 01d647
}