aboutsummaryrefslogtreecommitdiffstats
path: root/libqpdf
diff options
context:
space:
mode:
authorJay Berkenbilt <ejb@ql.org>2023-12-20 17:08:36 +0100
committerJay Berkenbilt <ejb@ql.org>2023-12-20 21:46:20 +0100
commitd61612a2e54d266d8fc4f55042080b780984272e (patch)
treeebefee30abcf242c70d55fb4b0c5841416bec7a9 /libqpdf
parentc5f622a09e6a68d87d3591346d872cf828cf82c7 (diff)
downloadqpdf-d61612a2e54d266d8fc4f55042080b780984272e.tar.zst
Bug fix: don't compress hint streams when --compress-streams=n
Diffstat (limited to 'libqpdf')
-rw-r--r--libqpdf/QPDFWriter.cc9
-rw-r--r--libqpdf/QPDF_linearization.cc21
2 files changed, 21 insertions, 9 deletions
diff --git a/libqpdf/QPDFWriter.cc b/libqpdf/QPDFWriter.cc
index 3085e6c0..981fc755 100644
--- a/libqpdf/QPDFWriter.cc
+++ b/libqpdf/QPDFWriter.cc
@@ -2289,15 +2289,20 @@ QPDFWriter::writeHintStream(int hint_id)
std::shared_ptr<Buffer> hint_buffer;
int S = 0;
int O = 0;
+ bool compressed = (m->compress_streams && !m->qdf_mode);
QPDF::Writer::generateHintStream(
- m->pdf, m->xref, m->lengths, m->obj_renumber_no_gen, hint_buffer, S, O);
+ m->pdf, m->xref, m->lengths, m->obj_renumber_no_gen, hint_buffer, S, O, compressed);
openObject(hint_id);
setDataKey(hint_id);
size_t hlen = hint_buffer->getSize();
- writeString("<< /Filter /FlateDecode /S ");
+ writeString("<< ");
+ if (compressed) {
+ writeString("/Filter /FlateDecode ");
+ }
+ writeString("/S ");
writeString(std::to_string(S));
if (O) {
writeString(" /O ");
diff --git a/libqpdf/QPDF_linearization.cc b/libqpdf/QPDF_linearization.cc
index 469b9933..1657d54a 100644
--- a/libqpdf/QPDF_linearization.cc
+++ b/libqpdf/QPDF_linearization.cc
@@ -1748,10 +1748,10 @@ QPDF::writeHSharedObject(BitWriter& w)
void
QPDF::writeHGeneric(BitWriter& w, HGeneric& t)
{
- w.writeBitsInt(t.first_object, 32); // 1
- w.writeBits(toULL(t.first_object_offset), 32); // 2
- w.writeBitsInt(t.nobjects, 32); // 3
- w.writeBitsInt(t.group_length, 32); // 4
+ w.writeBitsInt(t.first_object, 32); // 1
+ w.writeBits(toULL(t.first_object_offset), 32); // 2
+ w.writeBitsInt(t.nobjects, 32); // 3
+ w.writeBitsInt(t.group_length, 32); // 4
}
void
@@ -1761,7 +1761,8 @@ QPDF::generateHintStream(
std::map<int, int> const& obj_renumber,
std::shared_ptr<Buffer>& hint_buffer,
int& S,
- int& O)
+ int& O,
+ bool compressed)
{
// Populate actual hint table values
calculateHPageOffset(xref, lengths, obj_renumber);
@@ -1771,8 +1772,14 @@ QPDF::generateHintStream(
// Write the hint stream itself into a compressed memory buffer. Write through a counter so we
// can get offsets.
Pl_Buffer hint_stream("hint stream");
- Pl_Flate f("compress hint stream", &hint_stream, Pl_Flate::a_deflate);
- Pl_Count c("count", &f);
+ Pipeline* next = &hint_stream;
+ std::shared_ptr<Pipeline> flate;
+ if (compressed) {
+ flate =
+ std::make_shared<Pl_Flate>("compress hint stream", &hint_stream, Pl_Flate::a_deflate);
+ next = flate.get();
+ }
+ Pl_Count c("count", next);
BitWriter w(&c);
writeHPageOffset(w);