mirror of
https://github.com/qpdf/qpdf.git
synced 2024-12-22 10:58:58 +00:00
cb769c62e5
This comment expands all tabs using an 8-character tab-width. You should ignore this commit when using git blame or use git blame -w. In the early days, I used to use tabs where possible for indentation, since emacs did this automatically. In recent years, I have switched to only using spaces, which means qpdf source code has been a mixture of spaces and tabs. I have avoided cleaning this up because of not wanting gratuitous whitespaces change to cloud the output of git blame, but I changed my mind after discussing with users who view qpdf source code in editors/IDEs that have other tab widths by default and in light of the fact that I am planning to start applying automatic code formatting soon.
102 lines
2.2 KiB
C++
102 lines
2.2 KiB
C++
#include <iostream>
|
|
#include <string.h>
|
|
#include <stdlib.h>
|
|
|
|
#include <qpdf/QPDF.hh>
|
|
#include <qpdf/QPDFPageDocumentHelper.hh>
|
|
#include <qpdf/QPDFPageObjectHelper.hh>
|
|
#include <qpdf/QUtil.hh>
|
|
#include <qpdf/QIntC.hh>
|
|
|
|
static char const* whoami = 0;
|
|
|
|
void usage()
|
|
{
|
|
std::cerr << "Usage: " << whoami << " filename page-number" << std::endl
|
|
<< "Prints a dump of the objects in the content streams"
|
|
<< " of the given page." << std::endl
|
|
<< "Pages are numbered from 1." << std::endl;
|
|
exit(2);
|
|
}
|
|
|
|
class ParserCallbacks: public QPDFObjectHandle::ParserCallbacks
|
|
{
|
|
public:
|
|
virtual ~ParserCallbacks()
|
|
{
|
|
}
|
|
|
|
virtual void contentSize(size_t);
|
|
virtual void handleObject(QPDFObjectHandle, size_t offset, size_t length);
|
|
virtual void handleEOF();
|
|
};
|
|
|
|
void
|
|
ParserCallbacks::contentSize(size_t size)
|
|
{
|
|
std::cout << "content size: " << size << std::endl;
|
|
}
|
|
|
|
void
|
|
ParserCallbacks::handleObject(QPDFObjectHandle obj,
|
|
size_t offset, size_t length)
|
|
{
|
|
std::cout << obj.getTypeName() << ", offset=" << offset
|
|
<< ", length=" << length << ": ";
|
|
if (obj.isInlineImage())
|
|
{
|
|
std::cout << QUtil::hex_encode(obj.getInlineImageValue()) << std::endl;
|
|
}
|
|
else
|
|
{
|
|
std::cout << obj.unparse() << std::endl;
|
|
}
|
|
}
|
|
|
|
void
|
|
ParserCallbacks::handleEOF()
|
|
{
|
|
std::cout << "-EOF-" << std::endl;
|
|
}
|
|
|
|
int main(int argc, char* argv[])
|
|
{
|
|
whoami = QUtil::getWhoami(argv[0]);
|
|
|
|
// For libtool's sake....
|
|
if (strncmp(whoami, "lt-", 3) == 0)
|
|
{
|
|
whoami += 3;
|
|
}
|
|
|
|
if (argc != 3)
|
|
{
|
|
usage();
|
|
}
|
|
char const* filename = argv[1];
|
|
int pageno = QUtil::string_to_int(argv[2]);
|
|
|
|
try
|
|
{
|
|
QPDF pdf;
|
|
pdf.processFile(filename);
|
|
std::vector<QPDFPageObjectHelper> pages =
|
|
QPDFPageDocumentHelper(pdf).getAllPages();
|
|
if ((pageno < 1) || (QIntC::to_size(pageno) > pages.size()))
|
|
{
|
|
usage();
|
|
}
|
|
|
|
QPDFPageObjectHelper& page = pages.at(QIntC::to_size(pageno-1));
|
|
ParserCallbacks cb;
|
|
page.parseContents(&cb);
|
|
}
|
|
catch (std::exception& e)
|
|
{
|
|
std::cerr << whoami << ": " << e.what() << std::endl;
|
|
exit(2);
|
|
}
|
|
|
|
return 0;
|
|
}
|