2
1
mirror of https://github.com/qpdf/qpdf.git synced 2025-01-08 17:24:06 +00:00

Add QPDF::getObject to replace getObjectByObjGen and getObjectByID

For consistency with similar methods, e.g. replaceObject.
This commit is contained in:
m-holger 2022-08-01 19:22:37 +01:00
parent a9c0b02668
commit 1553868c4a
6 changed files with 34 additions and 18 deletions

View File

@ -385,6 +385,10 @@ class QPDF
// Retrieve an object by object ID and generation. Returns an // Retrieve an object by object ID and generation. Returns an
// indirect reference to it. // indirect reference to it.
QPDF_DLL QPDF_DLL
QPDFObjectHandle getObject(QPDFObjGen const&);
QPDF_DLL
QPDFObjectHandle getObject(int objid, int generation);
QPDF_DLL
QPDFObjectHandle getObjectByObjGen(QPDFObjGen const&); QPDFObjectHandle getObjectByObjGen(QPDFObjGen const&);
QPDF_DLL QPDF_DLL
QPDFObjectHandle getObjectByID(int objid, int generation); QPDFObjectHandle getObjectByID(int objid, int generation);

View File

@ -2148,7 +2148,7 @@ QPDF::reserveObjectIfNotExists(QPDFObjGen const& og)
resolve(og); resolve(og);
replaceObject(og, QPDFObjectHandle::Factory::makeReserved()); replaceObject(og, QPDFObjectHandle::Factory::makeReserved());
} }
return getObjectByObjGen(og); return getObject(og);
} }
QPDFObjectHandle QPDFObjectHandle
@ -2159,15 +2159,27 @@ QPDF::reserveStream(QPDFObjGen const& og)
} }
QPDFObjectHandle QPDFObjectHandle
QPDF::getObjectByObjGen(QPDFObjGen const& og) QPDF::getObject(QPDFObjGen const& og)
{ {
return QPDFObjectHandle::Factory::newIndirect(this, og); return QPDFObjectHandle::Factory::newIndirect(this, og);
} }
QPDFObjectHandle
QPDF::getObject(int objid, int generation)
{
return getObject(QPDFObjGen(objid, generation));
}
QPDFObjectHandle
QPDF::getObjectByObjGen(QPDFObjGen const& og)
{
return getObject(og);
}
QPDFObjectHandle QPDFObjectHandle
QPDF::getObjectByID(int objid, int generation) QPDF::getObjectByID(int objid, int generation)
{ {
return getObjectByObjGen(QPDFObjGen(objid, generation)); return getObject(QPDFObjGen(objid, generation));
} }
void void

View File

@ -183,7 +183,7 @@ QPDFAcroFormDocumentHelper::getFormFields()
analyze(); analyze();
std::vector<QPDFFormFieldObjectHelper> result; std::vector<QPDFFormFieldObjectHelper> result;
for (auto const& iter: this->m->field_to_annotations) { for (auto const& iter: this->m->field_to_annotations) {
result.push_back(this->qpdf.getObjectByObjGen(iter.first)); result.push_back(this->qpdf.getObject(iter.first));
} }
return result; return result;
} }

View File

@ -1897,7 +1897,7 @@ QPDFWriter::writeObjectStream(QPDFObjectHandle object)
// pass 1. // pass 1.
indicateProgress(true, false); indicateProgress(true, false);
} }
QPDFObjectHandle obj_to_write = this->m->pdf.getObjectByObjGen(obj); QPDFObjectHandle obj_to_write = this->m->pdf.getObject(obj);
if (obj_to_write.isStream()) { if (obj_to_write.isStream()) {
// This condition occurred in a fuzz input. Ideally we // This condition occurred in a fuzz input. Ideally we
// should block it at at parse time, but it's not // should block it at at parse time, but it's not

View File

@ -394,7 +394,7 @@ QPDF::JSONReactor::replaceObject(
auto og = to_replace.getObjGen(); auto og = to_replace.getObjGen();
this->reserved.erase(og); this->reserved.erase(og);
this->pdf.replaceObject(og, replacement); this->pdf.replaceObject(og, replacement);
auto oh = pdf.getObjectByObjGen(og); auto oh = pdf.getObject(og);
setObjectDescription(oh, value); setObjectDescription(oh, value);
} }

View File

@ -706,7 +706,7 @@ QPDF::getUncompressedObject(
return obj; return obj;
} else { } else {
int repl = (*(object_stream_data.find(obj.getObjectID()))).second; int repl = (*(object_stream_data.find(obj.getObjectID()))).second;
return getObjectByObjGen(QPDFObjGen(repl, 0)); return getObject(repl, 0);
} }
} }
@ -1381,9 +1381,9 @@ QPDF::calculateLinearizationData(std::map<int, int> const& object_stream_data)
stopOnError("found other than one root while" stopOnError("found other than one root while"
" calculating linearization data"); " calculating linearization data");
} }
this->m->part4.push_back(getObjectByObjGen(*(lc_root.begin()))); this->m->part4.push_back(getObject(*(lc_root.begin())));
for (auto const& og: lc_open_document) { for (auto const& og: lc_open_document) {
this->m->part4.push_back(getObjectByObjGen(og)); this->m->part4.push_back(getObject(og));
} }
// Part 6: first page objects. Note: implementation note 124 // Part 6: first page objects. Note: implementation note 124
@ -1412,11 +1412,11 @@ QPDF::calculateLinearizationData(std::map<int, int> const& object_stream_data)
// hint tables. // hint tables.
for (auto const& og: lc_first_page_private) { for (auto const& og: lc_first_page_private) {
this->m->part6.push_back(getObjectByObjGen(og)); this->m->part6.push_back(getObject(og));
} }
for (auto const& og: lc_first_page_shared) { for (auto const& og: lc_first_page_shared) {
this->m->part6.push_back(getObjectByObjGen(og)); this->m->part6.push_back(getObject(og));
} }
// Place the outline dictionary if it goes in the first page section. // Place the outline dictionary if it goes in the first page section.
@ -1462,7 +1462,7 @@ QPDF::calculateLinearizationData(std::map<int, int> const& object_stream_data)
for (auto const& og: this->m->obj_user_to_objects[ou]) { for (auto const& og: this->m->obj_user_to_objects[ou]) {
if (lc_other_page_private.count(og)) { if (lc_other_page_private.count(og)) {
lc_other_page_private.erase(og); lc_other_page_private.erase(og);
this->m->part7.push_back(getObjectByObjGen(og)); this->m->part7.push_back(getObject(og));
++this->m->c_page_offset_data.entries.at(i).nobjects; ++this->m->c_page_offset_data.entries.at(i).nobjects;
} }
} }
@ -1479,7 +1479,7 @@ QPDF::calculateLinearizationData(std::map<int, int> const& object_stream_data)
// Order is unimportant. // Order is unimportant.
for (auto const& og: lc_other_page_shared) { for (auto const& og: lc_other_page_shared) {
this->m->part8.push_back(getObjectByObjGen(og)); this->m->part8.push_back(getObject(og));
} }
// Part 9: other objects // Part 9: other objects
@ -1501,7 +1501,7 @@ QPDF::calculateLinearizationData(std::map<int, int> const& object_stream_data)
for (auto const& og: pages_ogs) { for (auto const& og: pages_ogs) {
if (lc_other.count(og)) { if (lc_other.count(og)) {
lc_other.erase(og); lc_other.erase(og);
this->m->part9.push_back(getObjectByObjGen(og)); this->m->part9.push_back(getObject(og));
} }
} }
@ -1531,7 +1531,7 @@ QPDF::calculateLinearizationData(std::map<int, int> const& object_stream_data)
for (auto const& og: ogs) { for (auto const& og: ogs) {
if (lc_thumbnail_private.count(og)) { if (lc_thumbnail_private.count(og)) {
lc_thumbnail_private.erase(og); lc_thumbnail_private.erase(og);
this->m->part9.push_back(getObjectByObjGen(og)); this->m->part9.push_back(getObject(og));
} }
} }
} }
@ -1544,7 +1544,7 @@ QPDF::calculateLinearizationData(std::map<int, int> const& object_stream_data)
// Place shared thumbnail objects // Place shared thumbnail objects
for (auto const& og: lc_thumbnail_shared) { for (auto const& og: lc_thumbnail_shared) {
this->m->part9.push_back(getObjectByObjGen(og)); this->m->part9.push_back(getObject(og));
} }
// Place outlines unless in first page // Place outlines unless in first page
@ -1554,7 +1554,7 @@ QPDF::calculateLinearizationData(std::map<int, int> const& object_stream_data)
// Place all remaining objects // Place all remaining objects
for (auto const& og: lc_other) { for (auto const& og: lc_other) {
this->m->part9.push_back(getObjectByObjGen(og)); this->m->part9.push_back(getObject(og));
} }
// Make sure we got everything exactly once. // Make sure we got everything exactly once.
@ -1656,7 +1656,7 @@ QPDF::pushOutlinesToPart(
lc_outlines.erase(outlines_og); lc_outlines.erase(outlines_og);
part.push_back(outlines); part.push_back(outlines);
for (auto const& og: lc_outlines) { for (auto const& og: lc_outlines) {
part.push_back(getObjectByObjGen(og)); part.push_back(getObject(og));
++this->m->c_outline_data.nobjects; ++this->m->c_outline_data.nobjects;
} }
} }