From 6154221edbb0e17e77da7defeeac5fe53121ef57 Mon Sep 17 00:00:00 2001 From: Jay Berkenbilt Date: Thu, 31 Dec 2020 13:57:21 -0500 Subject: QPDFPageObjectHelper: filterPageContents -> filterContents + form XObject --- libqpdf/QPDFPageObjectHelper.cc | 51 +++++++++++++++++++++-------------------- 1 file changed, 26 insertions(+), 25 deletions(-) (limited to 'libqpdf') diff --git a/libqpdf/QPDFPageObjectHelper.cc b/libqpdf/QPDFPageObjectHelper.cc index c26744ac..ce244253 100644 --- a/libqpdf/QPDFPageObjectHelper.cc +++ b/libqpdf/QPDFPageObjectHelper.cc @@ -435,7 +435,7 @@ QPDFPageObjectHelper::externalizeInlineImages(size_t min_size) QPDFObjectHandle::parse("<< /XObject << >> >>")); InlineImageTracker iit(this->oh.getOwningQPDF(), min_size, resources); Pl_Buffer b("new page content"); - filterPageContents(&iit, &b); + filterContents(&iit, &b); if (iit.any_images) { getObjectHandle().replaceKey( @@ -504,7 +504,22 @@ QPDFPageObjectHelper::filterPageContents( QPDFObjectHandle::TokenFilter* filter, Pipeline* next) { - this->oh.filterPageContents(filter, next); + return filterContents(filter, next); +} + +void +QPDFPageObjectHelper::filterContents( + QPDFObjectHandle::TokenFilter* filter, + Pipeline* next) +{ + if (this->oh.isFormXObject()) + { + this->oh.filterAsContents(filter, next); + } + else + { + this->oh.filterPageContents(filter, next); + } } void @@ -554,23 +569,21 @@ NameWatcher::handleToken(QPDFTokenizer::Token const& token) void QPDFPageObjectHelper::removeUnreferencedResourcesHelper( - QPDFObjectHandle oh, std::set& seen, - std::function get_resource, - std::function filter_content) + QPDFPageObjectHelper ph, std::set& seen) { - if (seen.count(oh.getObjGen())) + if (seen.count(ph.oh.getObjGen())) { return; } - seen.insert(oh.getObjGen()); + seen.insert(ph.oh.getObjGen()); NameWatcher nw; try { - filter_content(&nw); + ph.filterContents(&nw); } catch (std::exception& e) { - oh.warnIfPossible( + ph.oh.warnIfPossible( std::string("Unable to parse content stream: ") + e.what() + "; not attempting to remove unreferenced objects from this page"); return; @@ -578,7 +591,7 @@ QPDFPageObjectHelper::removeUnreferencedResourcesHelper( if (nw.saw_bad) { QTC::TC("qpdf", "QPDFPageObjectHelper bad token finding names"); - oh.warnIfPossible( + ph.oh.warnIfPossible( "Bad token found while scanning content stream; " "not attempting to remove unreferenced objects from this page"); return; @@ -591,7 +604,7 @@ QPDFPageObjectHelper::removeUnreferencedResourcesHelper( std::vector to_filter; to_filter.push_back("/Font"); to_filter.push_back("/XObject"); - QPDFObjectHandle resources = get_resource(); + QPDFObjectHandle resources = ph.getAttribute("/Resources", true); for (std::vector::iterator d_iter = to_filter.begin(); d_iter != to_filter.end(); ++d_iter) { @@ -615,14 +628,7 @@ QPDFPageObjectHelper::removeUnreferencedResourcesHelper( { QTC::TC("qpdf", "QPDFPageObjectHelper filter form xobject"); removeUnreferencedResourcesHelper( - resource.getDict(), seen, - [&resource]() { - return QPDFPageObjectHelper(resource) - .getAttribute("/Resources", true); - }, - [&resource](QPDFObjectHandle::TokenFilter* f) { - resource.filterAsContents(f); - }); + QPDFPageObjectHelper(resource), seen); } } } @@ -632,12 +638,7 @@ void QPDFPageObjectHelper::removeUnreferencedResources() { std::set seen; - removeUnreferencedResourcesHelper( - this->oh, seen, - [this]() { return this->getAttribute("/Resources", true); }, - [this](QPDFObjectHandle::TokenFilter* f) { - this->filterPageContents(f); - }); + removeUnreferencedResourcesHelper(*this, seen); } QPDFPageObjectHelper -- cgit v1.2.3-54-g00ecf