2
1
mirror of https://github.com/qpdf/qpdf.git synced 2025-01-05 08:02:11 +00:00

Add newline-before-endstream option (fixes #103)

This commit is contained in:
Jay Berkenbilt 2017-07-29 12:18:03 -04:00
parent 6a7d53ad2b
commit f37d399d82
6 changed files with 41 additions and 2 deletions

View File

@ -1,5 +1,11 @@
2017-07-29 Jay Berkenbilt <ejb@ql.org> 2017-07-29 Jay Berkenbilt <ejb@ql.org>
* Add --newline-before-endstream command-line option and
setNewlineBeforeEndstream method to QPDFWriter. This forces qpdf
to always add a newline before the endstream keyword. It is a
necessary but not sufficient condition for PDF/A compliance. Fixes
#103.
* Handle zlib data errors when decoding streams. Fixes #106. * Handle zlib data errors when decoding streams. Fixes #106.
* Improve handling of files where the "stream" keyword is not * Improve handling of files where the "stream" keyword is not

View File

@ -161,6 +161,11 @@ class QPDFWriter
QPDF_DLL QPDF_DLL
void setPreserveUnreferencedObjects(bool); void setPreserveUnreferencedObjects(bool);
// Always write a newline before the endstream keyword. This helps
// with PDF/A compliance, though it is not sufficient for it.
QPDF_DLL
void setNewlineBeforeEndstream(bool);
// Set the minimum PDF version. If the PDF version of the input // Set the minimum PDF version. If the PDF version of the input
// file (or previously set minimum version) is less than the // file (or previously set minimum version) is less than the
// version passed to this method, the PDF version of the output // version passed to this method, the PDF version of the output
@ -434,6 +439,7 @@ class QPDFWriter
bool qdf_mode; bool qdf_mode;
bool precheck_streams; bool precheck_streams;
bool preserve_unreferenced_objects; bool preserve_unreferenced_objects;
bool newline_before_endstream;
bool static_id; bool static_id;
bool suppress_original_object_ids; bool suppress_original_object_ids;
bool direct_stream_lengths; bool direct_stream_lengths;

View File

@ -59,6 +59,7 @@ QPDFWriter::init()
qdf_mode = false; qdf_mode = false;
precheck_streams = false; precheck_streams = false;
preserve_unreferenced_objects = false; preserve_unreferenced_objects = false;
newline_before_endstream = false;
static_id = false; static_id = false;
suppress_original_object_ids = false; suppress_original_object_ids = false;
direct_stream_lengths = true; direct_stream_lengths = true;
@ -190,6 +191,12 @@ QPDFWriter::setPreserveUnreferencedObjects(bool val)
this->preserve_unreferenced_objects = val; this->preserve_unreferenced_objects = val;
} }
void
QPDFWriter::setNewlineBeforeEndstream(bool val)
{
this->newline_before_endstream = val;
}
void void
QPDFWriter::setMinimumPDFVersion(std::string const& version) QPDFWriter::setMinimumPDFVersion(std::string const& version)
{ {
@ -1580,7 +1587,7 @@ QPDFWriter::unparseObject(QPDFObjectHandle object, int level,
char last_char = this->pipeline->getLastChar(); char last_char = this->pipeline->getLastChar();
popPipelineStack(); popPipelineStack();
if (this->qdf_mode) if (this->qdf_mode || this->newline_before_endstream)
{ {
if (last_char != '\n') if (last_char != '\n')
{ {

View File

@ -204,6 +204,7 @@ familiar with the PDF file format or who are PDF developers.\n\
--ignore-xref-streams tells qpdf to ignore any cross-reference streams\n\ --ignore-xref-streams tells qpdf to ignore any cross-reference streams\n\
--precheck-streams precheck ability to decode streams\n\ --precheck-streams precheck ability to decode streams\n\
--preserve-unreferenced preserve unreferenced objects\n\ --preserve-unreferenced preserve unreferenced objects\n\
--newline-before-endstream always put a newline before endstream\n\
--qdf turns on \"QDF mode\" (below)\n\ --qdf turns on \"QDF mode\" (below)\n\
--min-version=version sets the minimum PDF version of the output file\n\ --min-version=version sets the minimum PDF version of the output file\n\
--force-version=version forces this to be the PDF version of the output file\n\ --force-version=version forces this to be the PDF version of the output file\n\
@ -1032,6 +1033,7 @@ int main(int argc, char* argv[])
bool qdf_mode = false; bool qdf_mode = false;
bool precheck_streams = false; bool precheck_streams = false;
bool preserve_unreferenced_objects = false; bool preserve_unreferenced_objects = false;
bool newline_before_endstream = false;
std::string min_version; std::string min_version;
std::string force_version; std::string force_version;
@ -1225,6 +1227,10 @@ int main(int argc, char* argv[])
{ {
preserve_unreferenced_objects = true; preserve_unreferenced_objects = true;
} }
else if (strcmp(arg, "newline-before-endstream") == 0)
{
newline_before_endstream = true;
}
else if (strcmp(arg, "min-version") == 0) else if (strcmp(arg, "min-version") == 0)
{ {
if (parameter == 0) if (parameter == 0)
@ -1724,6 +1730,10 @@ int main(int argc, char* argv[])
{ {
w.setPreserveUnreferencedObjects(true); w.setPreserveUnreferencedObjects(true);
} }
if (newline_before_endstream)
{
w.setNewlineBeforeEndstream(true);
}
if (normalize_set) if (normalize_set)
{ {
w.setContentNormalization(normalize); w.setContentNormalization(normalize);

View File

@ -206,7 +206,7 @@ $td->runtest("remove page we don't have",
show_ntests(); show_ntests();
# ---------- # ----------
$td->notify("--- Miscellaneous Tests ---"); $td->notify("--- Miscellaneous Tests ---");
$n_tests += 89; $n_tests += 91;
$td->runtest("qpdf version", $td->runtest("qpdf version",
{$td->COMMAND => "qpdf --version"}, {$td->COMMAND => "qpdf --version"},
@ -618,6 +618,16 @@ $td->runtest("split content stream errors",
$td->EXIT_STATUS => 3}, $td->EXIT_STATUS => 3},
$td->NORMALIZE_NEWLINES); $td->NORMALIZE_NEWLINES);
$td->runtest("newline before endstream",
{$td->COMMAND =>
"qpdf --static-id --newline-before-endstream" .
" minimal.pdf a.pdf"},
{$td->STRING => "", $td->EXIT_STATUS => 0},
$td->NORMALIZE_NEWLINES);
$td->runtest("check output",
{$td->FILE => "a.pdf"},
{$td->FILE => "newline-before-endstream.pdf"});
show_ntests(); show_ntests();
# ---------- # ----------

Binary file not shown.