mirror of
https://github.com/qpdf/qpdf.git
synced 2024-12-22 19:08:59 +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.
125 lines
3.4 KiB
C++
125 lines
3.4 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/Buffer.hh>
|
|
#include <qpdf/QPDFWriter.hh>
|
|
|
|
static char const* whoami = 0;
|
|
|
|
void usage()
|
|
{
|
|
std::cerr << "Usage: " << whoami << " infile.pdf outfile.pdf [in-password]"
|
|
<< std::endl
|
|
<< "Double size of all pages in infile.pdf;"
|
|
<< " write output to outfile.pdf" << std::endl;
|
|
exit(2);
|
|
}
|
|
|
|
static void doubleBoxSize(QPDFObjectHandle& page, char const* box_name)
|
|
{
|
|
// If there is a box of this name, replace it with a new box whose
|
|
// elements are double the values of the original box.
|
|
QPDFObjectHandle box = page.getKey(box_name);
|
|
if (box.isNull())
|
|
{
|
|
return;
|
|
}
|
|
if (! (box.isArray() && (box.getArrayNItems() == 4)))
|
|
{
|
|
throw std::runtime_error(std::string("box ") + box_name +
|
|
" is not an array of four elements");
|
|
}
|
|
std::vector<QPDFObjectHandle> doubled;
|
|
for (int i = 0; i < 4; ++i)
|
|
{
|
|
doubled.push_back(
|
|
QPDFObjectHandle::newReal(
|
|
box.getArrayItem(i).getNumericValue() * 2.0, 2));
|
|
}
|
|
page.replaceKey(box_name, QPDFObjectHandle::newArray(doubled));
|
|
}
|
|
|
|
int main(int argc, char* argv[])
|
|
{
|
|
whoami = QUtil::getWhoami(argv[0]);
|
|
|
|
// For libtool's sake....
|
|
if (strncmp(whoami, "lt-", 3) == 0)
|
|
{
|
|
whoami += 3;
|
|
}
|
|
|
|
// For test suite
|
|
bool static_id = false;
|
|
if ((argc > 1) && (strcmp(argv[1], " --static-id") == 0))
|
|
{
|
|
static_id = true;
|
|
--argc;
|
|
++argv;
|
|
}
|
|
|
|
if (! ((argc == 3) || (argc == 4)))
|
|
{
|
|
usage();
|
|
}
|
|
|
|
char const* infilename = argv[1];
|
|
char const* outfilename = argv[2];
|
|
char const* password = (argc == 4) ? argv[3] : "";
|
|
|
|
// Text to prepend to each page's contents
|
|
std::string content = "2 0 0 2 0 0 cm\n";
|
|
|
|
try
|
|
{
|
|
QPDF qpdf;
|
|
qpdf.processFile(infilename, password);
|
|
|
|
std::vector<QPDFPageObjectHelper> pages =
|
|
QPDFPageDocumentHelper(qpdf).getAllPages();
|
|
for (std::vector<QPDFPageObjectHelper>::iterator iter =
|
|
pages.begin();
|
|
iter != pages.end(); ++iter)
|
|
{
|
|
QPDFPageObjectHelper& ph(*iter);
|
|
QPDFObjectHandle page = ph.getObjectHandle();
|
|
|
|
// Prepend the buffer to the page's contents
|
|
ph.addPageContents(
|
|
QPDFObjectHandle::newStream(&qpdf, content), true);
|
|
|
|
// Double the size of each of the content boxes
|
|
doubleBoxSize(page, "/MediaBox");
|
|
doubleBoxSize(page, "/CropBox");
|
|
doubleBoxSize(page, "/BleedBox");
|
|
doubleBoxSize(page, "/TrimBox");
|
|
doubleBoxSize(page, "/ArtBox");
|
|
}
|
|
|
|
// Write out a new file
|
|
QPDFWriter w(qpdf, outfilename);
|
|
if (static_id)
|
|
{
|
|
// For the test suite, uncompress streams and use static
|
|
// IDs.
|
|
w.setStaticID(true); // for testing only
|
|
w.setStreamDataMode(qpdf_s_uncompress);
|
|
}
|
|
w.write();
|
|
std::cout << whoami << ": new file written to " << outfilename
|
|
<< std::endl;
|
|
}
|
|
catch (std::exception &e)
|
|
{
|
|
std::cerr << whoami << " processing file " << infilename << ": "
|
|
<< e.what() << std::endl;
|
|
exit(2);
|
|
}
|
|
|
|
return 0;
|
|
}
|