diff --git a/include/qpdf/QPDFObjectHandle.hh b/include/qpdf/QPDFObjectHandle.hh index ba58fcf3..f8bcb055 100644 --- a/include/qpdf/QPDFObjectHandle.hh +++ b/include/qpdf/QPDFObjectHandle.hh @@ -1628,7 +1628,7 @@ class QPDFObjectHandle void objectWarning(std::string const& warning); void assertType(char const* type_name, bool istype); bool dereference(); - void copyObject(std::set& visited, bool stop_at_streams); + void makeDirect(std::set& visited, bool stop_at_streams); void disconnect(); void setParsedOffset(qpdf_offset_t offset); void parseContentStream_internal( diff --git a/libqpdf/QPDFObjectHandle.cc b/libqpdf/QPDFObjectHandle.cc index 3362d5e6..70305779 100644 --- a/libqpdf/QPDFObjectHandle.cc +++ b/libqpdf/QPDFObjectHandle.cc @@ -2218,19 +2218,10 @@ QPDFObjectHandle::unsafeShallowCopy() } void -QPDFObjectHandle::copyObject( +QPDFObjectHandle::makeDirect( std::set& visited, bool stop_at_streams) { assertInitialized(); - if (isStream()) { - QTC::TC( - "qpdf", "QPDFObjectHandle copy stream", stop_at_streams ? 0 : 1); - if (stop_at_streams) { - return; - } - throw std::runtime_error( - "attempt to make a stream into a direct object"); - } auto cur_og = getObjGen(); if (cur_og.getObj() != 0) { @@ -2243,40 +2234,41 @@ QPDFObjectHandle::copyObject( visited.insert(cur_og); } - if (isReserved()) { - throw std::logic_error("QPDFObjectHandle: attempting to make a" - " reserved object handle direct"); - } - - std::shared_ptr new_obj; - if (isBool() || isInteger() || isName() || isNull() || isReal() || isString()) { - new_obj = obj->copy(true); + this->obj = obj->copy(true); } else if (isArray()) { std::vector items; auto array = asArray(); int n = array->getNItems(); for (int i = 0; i < n; ++i) { items.push_back(array->getItem(i)); - items.back().copyObject(visited, stop_at_streams); + items.back().makeDirect(visited, stop_at_streams); } - new_obj = QPDF_Array::create(items); + this->obj = QPDF_Array::create(items); } else if (isDictionary()) { std::map items; auto dict = asDictionary(); for (auto const& key: getKeys()) { items[key] = dict->getKey(key); - items[key].copyObject(visited, stop_at_streams); + items[key].makeDirect(visited, stop_at_streams); } - new_obj = QPDF_Dictionary::create(items); + this->obj = QPDF_Dictionary::create(items); + } else if (isStream()) { + QTC::TC( + "qpdf", "QPDFObjectHandle copy stream", stop_at_streams ? 0 : 1); + if (!stop_at_streams) { + throw std::runtime_error( + "attempt to make a stream into a direct object"); + } + } else if (isReserved()) { + throw std::logic_error("QPDFObjectHandle: attempting to make a" + " reserved object handle direct"); } else { throw std::logic_error("QPDFObjectHandle::makeDirectInternal: " "unknown object type"); } - this->obj = new_obj; - if (cur_og.getObj()) { visited.erase(cur_og); } @@ -2304,7 +2296,7 @@ void QPDFObjectHandle::makeDirect(bool allow_streams) { std::set visited; - copyObject(visited, allow_streams); + makeDirect(visited, allow_streams); } void