aboutsummaryrefslogtreecommitdiffstats
path: root/libqpdf/QPDF_optimization.cc
diff options
context:
space:
mode:
authorJay Berkenbilt <ejb@ql.org>2010-03-27 16:42:17 +0100
committerJay Berkenbilt <ejb@ql.org>2010-03-27 16:42:17 +0100
commit218900d2c3d155ee139338414f7a57921636de38 (patch)
tree1166267136cfb3a9be33d6fc50ac5b74e35ac6f7 /libqpdf/QPDF_optimization.cc
parent028f106bee8602632435c78c1749370fbdd13780 (diff)
downloadqpdf-218900d2c3d155ee139338414f7a57921636de38.tar.zst
flatten scalar references for unreferenced objects
git-svn-id: svn+q:///qpdf/trunk@946 71b93d88-0707-0410-a8cf-f5a4172ac649
Diffstat (limited to 'libqpdf/QPDF_optimization.cc')
-rw-r--r--libqpdf/QPDF_optimization.cc19
1 files changed, 13 insertions, 6 deletions
diff --git a/libqpdf/QPDF_optimization.cc b/libqpdf/QPDF_optimization.cc
index e8d20fd5..872da859 100644
--- a/libqpdf/QPDF_optimization.cc
+++ b/libqpdf/QPDF_optimization.cc
@@ -69,18 +69,25 @@ QPDF::flattenScalarReferences()
queue.push_back(this->trailer);
std::set<ObjGen> visited;
+ // Add every object in the xref table to the queue. This ensures
+ // that we flatten scalar references in unreferenced objects.
+ // This becomes important if we are preserving object streams in a
+ // file that has unreferenced objects in its object streams. (See
+ // QPDF bug 2974522 at SourceForge.)
+ for (std::map<ObjGen, QPDFXRefEntry>::iterator iter =
+ this->xref_table.begin();
+ iter != this->xref_table.end(); ++iter)
+ {
+ ObjGen const& og = (*iter).first;
+ queue.push_back(getObjectByID(og.obj, og.gen));
+ }
+
while (! queue.empty())
{
QPDFObjectHandle node = queue.front();
queue.pop_front();
if (node.isIndirect())
{
- if (node.isScalar())
- {
- throw std::logic_error(
- "INTERNAL ERROR:"
- " flattenScalarReferences landed at indirect scalar");
- }
ObjGen og(node.getObjectID(), node.getGeneration());
if (visited.count(og) > 0)
{