aboutsummaryrefslogtreecommitdiffstats
path: root/libqpdf
diff options
context:
space:
mode:
authorm-holger <m-holger@kubitscheck.org>2023-03-25 19:23:39 +0100
committerm-holger <m-holger@kubitscheck.org>2023-04-01 13:24:52 +0200
commitea5164938e77cb968003fe06f98b87f648319bbf (patch)
treeb9efaeca90bf5a9de936be74b124819cfb915455 /libqpdf
parent9e30de80326ad88c155725c66e3d444232119deb (diff)
downloadqpdf-ea5164938e77cb968003fe06f98b87f648319bbf.tar.zst
Remove temporary OHArray
Diffstat (limited to 'libqpdf')
-rw-r--r--libqpdf/CMakeLists.txt1
-rw-r--r--libqpdf/OHArray.cc5
-rw-r--r--libqpdf/QPDF_Array.cc55
-rw-r--r--libqpdf/qpdf/OHArray.hh21
-rw-r--r--libqpdf/qpdf/QPDF_Array.hh9
5 files changed, 29 insertions, 62 deletions
diff --git a/libqpdf/CMakeLists.txt b/libqpdf/CMakeLists.txt
index 2d857f45..5e3a628e 100644
--- a/libqpdf/CMakeLists.txt
+++ b/libqpdf/CMakeLists.txt
@@ -116,7 +116,6 @@ set(libqpdf_SOURCES
SecureRandomDataProvider.cc
SF_FlateLzwDecode.cc
SparseOHArray.cc
- OHArray.cc
qpdf-c.cc
qpdfjob-c.cc
qpdflogger-c.cc)
diff --git a/libqpdf/OHArray.cc b/libqpdf/OHArray.cc
deleted file mode 100644
index 377b1a36..00000000
--- a/libqpdf/OHArray.cc
+++ /dev/null
@@ -1,5 +0,0 @@
-#include <qpdf/OHArray.hh>
-
-OHArray::OHArray()
-{
-}
diff --git a/libqpdf/QPDF_Array.cc b/libqpdf/QPDF_Array.cc
index c7a9f315..620b75eb 100644
--- a/libqpdf/QPDF_Array.cc
+++ b/libqpdf/QPDF_Array.cc
@@ -29,7 +29,7 @@ QPDF_Array::QPDF_Array(SparseOHArray const& items) :
{
}
-QPDF_Array::QPDF_Array(OHArray const& items) :
+QPDF_Array::QPDF_Array(std::vector<std::shared_ptr<QPDFObject>> const& items) :
QPDFValue(::ot_array, "array"),
sparse(false),
elements(items)
@@ -56,7 +56,7 @@ QPDF_Array::create(SparseOHArray const& items)
}
std::shared_ptr<QPDFObject>
-QPDF_Array::create(OHArray const& items)
+QPDF_Array::create(std::vector<std::shared_ptr<QPDFObject>> const& items)
{
return do_create(new QPDF_Array(items));
}
@@ -70,10 +70,10 @@ QPDF_Array::copy(bool shallow)
if (shallow) {
return create(elements);
} else {
- OHArray result;
- result.elements.reserve(elements.elements.size());
- for (auto const& element: elements.elements) {
- result.elements.push_back(
+ std::vector<std::shared_ptr<QPDFObject>> result;
+ result.reserve(elements.size());
+ for (auto const& element: elements) {
+ result.push_back(
element
? (element->getObjGen().isIndirect() ? element
: element->copy())
@@ -90,7 +90,7 @@ QPDF_Array::disconnect()
if (sparse) {
sp_elements.disconnect();
} else {
- for (auto const& iter: elements.elements) {
+ for (auto const& iter: elements) {
if (iter) {
QPDFObjectHandle::DisconnectAccess::disconnect(iter);
}
@@ -112,7 +112,7 @@ QPDF_Array::unparse()
return result;
} else {
std::string result = "[ ";
- auto size = elements.elements.size();
+ auto size = elements.size();
for (int i = 0; i < int(size); ++i) {
result += getItem(i).unparse();
result += " ";
@@ -134,7 +134,7 @@ QPDF_Array::getJSON(int json_version)
return j;
} else {
JSON j = JSON::makeArray();
- size_t size = elements.elements.size();
+ size_t size = elements.size();
for (int i = 0; i < int(size); ++i) {
j.addArrayElement(getItem(i).getJSON(json_version));
}
@@ -150,7 +150,7 @@ QPDF_Array::getNItems() const
// a lot of code.
return QIntC::to_int(sp_elements.size());
} else {
- return QIntC::to_int(elements.elements.size());
+ return QIntC::to_int(elements.size());
}
}
@@ -164,11 +164,11 @@ QPDF_Array::getItem(int n) const
}
return sp_elements.at(QIntC::to_size(n));
} else {
- if ((n < 0) || (n >= QIntC::to_int(elements.elements.size()))) {
+ if ((n < 0) || (n >= QIntC::to_int(elements.size()))) {
throw std::logic_error(
"INTERNAL ERROR: bounds error accessing QPDF_Array element");
}
- auto const& obj = elements.elements.at(size_t(n));
+ auto const& obj = elements.at(size_t(n));
return obj ? obj : null_oh;
}
}
@@ -182,8 +182,7 @@ QPDF_Array::getAsVector(std::vector<QPDFObjectHandle>& v) const
v.push_back(sp_elements.at(i));
}
} else {
- v = std::vector<QPDFObjectHandle>(
- elements.elements.cbegin(), elements.elements.cend());
+ v = std::vector<QPDFObjectHandle>(elements.cbegin(), elements.cend());
}
}
@@ -194,10 +193,10 @@ QPDF_Array::setItem(int n, QPDFObjectHandle const& oh)
sp_elements.setAt(QIntC::to_size(n), oh);
} else {
size_t idx = size_t(n);
- if (n < 0 || idx >= elements.elements.size()) {
+ if (n < 0 || idx >= elements.size()) {
throw std::logic_error("bounds error setting item in QPDF_Array");
}
- elements.elements[idx] = oh.getObj();
+ elements[idx] = oh.getObj();
}
}
@@ -210,9 +209,9 @@ QPDF_Array::setFromVector(std::vector<QPDFObjectHandle> const& v)
sp_elements.append(iter);
}
} else {
- elements = OHArray();
+ elements.resize(0);
for (auto const& iter: v) {
- elements.elements.push_back(iter.getObj());
+ elements.push_back(iter.getObj());
}
}
}
@@ -231,10 +230,7 @@ QPDF_Array::setFromVector(std::vector<std::shared_ptr<QPDFObject>>&& v)
}
}
} else {
- elements = OHArray();
- for (auto&& item: v) {
- elements.elements.push_back(std::move(item));
- }
+ elements = std::move(v);
}
}
@@ -251,17 +247,16 @@ QPDF_Array::insertItem(int at, QPDFObjectHandle const& item)
} else {
// As special case, also allow insert beyond the end
size_t idx = QIntC::to_size(at);
- if ((at < 0) || (at > QIntC::to_int(elements.elements.size()))) {
+ if ((at < 0) || (at > QIntC::to_int(elements.size()))) {
throw std::logic_error(
"INTERNAL ERROR: bounds error accessing QPDF_Array element");
}
- if (idx == elements.elements.size()) {
+ if (idx == elements.size()) {
// Allow inserting to the last position
- elements.elements.push_back(item.getObj());
+ elements.push_back(item.getObj());
} else {
int n = int(idx);
- elements.elements.insert(
- elements.elements.cbegin() + n, item.getObj());
+ elements.insert(elements.cbegin() + n, item.getObj());
}
}
}
@@ -272,7 +267,7 @@ QPDF_Array::appendItem(QPDFObjectHandle const& item)
if (sparse) {
sp_elements.append(item);
} else {
- elements.elements.push_back(item.getObj());
+ elements.push_back(item.getObj());
}
}
@@ -283,10 +278,10 @@ QPDF_Array::eraseItem(int at)
sp_elements.erase(QIntC::to_size(at));
} else {
size_t idx = QIntC::to_size(at);
- if (idx >= elements.elements.size()) {
+ if (idx >= elements.size()) {
throw std::logic_error("bounds error erasing item from OHArray");
}
int n = int(idx);
- elements.elements.erase(elements.elements.cbegin() + n);
+ elements.erase(elements.cbegin() + n);
}
}
diff --git a/libqpdf/qpdf/OHArray.hh b/libqpdf/qpdf/OHArray.hh
deleted file mode 100644
index 563145c2..00000000
--- a/libqpdf/qpdf/OHArray.hh
+++ /dev/null
@@ -1,21 +0,0 @@
-#ifndef QPDF_OHARRAY_HH
-#define QPDF_OHARRAY_HH
-
-#include <qpdf/QPDFObjectHandle.hh>
-#include <qpdf/QPDFObject_private.hh>
-
-#include <vector>
-
-class QPDF_Array;
-
-class OHArray
-{
- public:
- OHArray();
-
- private:
- friend class QPDF_Array;
- std::vector<std::shared_ptr<QPDFObject>> elements;
-};
-
-#endif // QPDF_OHARRAY_HH
diff --git a/libqpdf/qpdf/QPDF_Array.hh b/libqpdf/qpdf/QPDF_Array.hh
index 00c7f59d..b52efeb6 100644
--- a/libqpdf/qpdf/QPDF_Array.hh
+++ b/libqpdf/qpdf/QPDF_Array.hh
@@ -3,9 +3,7 @@
#include <qpdf/QPDFValue.hh>
-#include <qpdf/OHArray.hh>
#include <qpdf/SparseOHArray.hh>
-#include <list>
#include <vector>
class QPDF_Array: public QPDFValue
@@ -17,7 +15,8 @@ class QPDF_Array: public QPDFValue
static std::shared_ptr<QPDFObject>
create(std::vector<std::shared_ptr<QPDFObject>>&& items, bool sparse);
static std::shared_ptr<QPDFObject> create(SparseOHArray const& items);
- static std::shared_ptr<QPDFObject> create(OHArray const& items);
+ static std::shared_ptr<QPDFObject>
+ create(std::vector<std::shared_ptr<QPDFObject>> const& items);
virtual std::shared_ptr<QPDFObject> copy(bool shallow = false);
virtual std::string unparse();
virtual JSON getJSON(int json_version);
@@ -38,10 +37,10 @@ class QPDF_Array: public QPDFValue
QPDF_Array(std::vector<QPDFObjectHandle> const& items);
QPDF_Array(std::vector<std::shared_ptr<QPDFObject>>&& items, bool sparse);
QPDF_Array(SparseOHArray const& items);
- QPDF_Array(OHArray const& items);
+ QPDF_Array(std::vector<std::shared_ptr<QPDFObject>> const& items);
bool sparse{false};
SparseOHArray sp_elements;
- OHArray elements;
+ std::vector<std::shared_ptr<QPDFObject>> elements;
};
#endif // QPDF_ARRAY_HH