2
1
mirror of https://github.com/qpdf/qpdf.git synced 2025-01-25 16:18:26 +00:00
qpdf/examples/qpdf-job.cc

104 lines
2.6 KiB
C++
Raw Normal View History

2022-01-26 15:46:28 -05:00
#include <qpdf/QPDFJob.hh>
#include <qpdf/QUtil.hh>
#include <iostream>
2022-01-26 15:46:28 -05:00
// This program is a simple demonstration of different ways to use the QPDFJob API.
2022-01-26 15:46:28 -05:00
static char const* whoami = nullptr;
2022-01-26 15:46:28 -05:00
static void
usage()
2022-01-26 15:46:28 -05:00
{
std::cerr << "Usage: " << whoami << std::endl
<< "This program linearizes the first page of in.pdf to out1.pdf, out2.pdf, and"
<< std::endl
<< " out3.pdf, each demonstrating a different way to use the QPDFJob API"
<< std::endl;
2022-01-26 15:46:28 -05:00
exit(2);
}
int
main(int argc, char* argv[])
2022-01-26 15:46:28 -05:00
{
whoami = QUtil::getWhoami(argv[0]);
if (argc != 1) {
usage();
}
// The examples below all catch std::exception. Note that QPDFUsage can be caught separately to
// report on errors in using the API itself. For CLI, this is command-line usage. For JSON or
// the API, it would be errors from the equivalent invocation.
// Note that staticId is used for testing only.
try {
// Use the config API
2022-01-26 15:46:28 -05:00
QPDFJob j;
j.config()
->inputFile("in.pdf")
->outputFile("out1.pdf")
2022-01-26 15:46:28 -05:00
->pages()
->pageSpec(".", "1")
2022-01-26 15:46:28 -05:00
->endPages()
->linearize()
->staticId() // for testing only
->compressStreams("n") // avoid dependency on zlib output
->checkConfiguration();
2022-01-26 15:46:28 -05:00
j.run();
std::cout << "out1 status: " << j.getExitCode() << std::endl;
} catch (std::exception& e) {
std::cerr << "exception: " << e.what() << std::endl;
return 2;
}
try {
char const* new_argv[] = {
whoami,
"in.pdf",
"out2.pdf",
"--linearize",
"--pages",
".",
"1",
"--",
"--static-id",
"--compress-streams=n", // avoid dependency on zlib output
nullptr};
QPDFJob j;
j.initializeFromArgv(new_argv);
j.run();
std::cout << "out2 status: " << j.getExitCode() << std::endl;
} catch (std::exception& e) {
2022-01-26 15:46:28 -05:00
std::cerr << "exception: " << e.what() << std::endl;
return 2;
}
try {
// Use the JSON API
QPDFJob j;
j.initializeFromJson(R"({
"inputFile": "in.pdf",
"outputFile": "out3.pdf",
"staticId": "",
"linearize": "",
"compressStreams": "n",
"pages": [
{
"file": ".",
"range": "1"
}
]
}
)");
j.run();
std::cout << "out3 status: " << j.getExitCode() << std::endl;
} catch (std::exception& e) {
std::cerr << "exception: " << e.what() << std::endl;
return 2;
}
2022-01-26 15:46:28 -05:00
return 0;
}