Commit ea5164938e77cb968003fe06f98b87f648319bbf

Authored by m-holger
1 parent 9e30de80

Remove temporary OHArray

libqpdf/CMakeLists.txt
@@ -116,7 +116,6 @@ set(libqpdf_SOURCES @@ -116,7 +116,6 @@ set(libqpdf_SOURCES
116 SecureRandomDataProvider.cc 116 SecureRandomDataProvider.cc
117 SF_FlateLzwDecode.cc 117 SF_FlateLzwDecode.cc
118 SparseOHArray.cc 118 SparseOHArray.cc
119 - OHArray.cc  
120 qpdf-c.cc 119 qpdf-c.cc
121 qpdfjob-c.cc 120 qpdfjob-c.cc
122 qpdflogger-c.cc) 121 qpdflogger-c.cc)
libqpdf/OHArray.cc deleted
1 -#include <qpdf/OHArray.hh>  
2 -  
3 -OHArray::OHArray()  
4 -{  
5 -}  
libqpdf/QPDF_Array.cc
@@ -29,7 +29,7 @@ QPDF_Array::QPDF_Array(SparseOHArray const&amp; items) : @@ -29,7 +29,7 @@ QPDF_Array::QPDF_Array(SparseOHArray const&amp; items) :
29 { 29 {
30 } 30 }
31 31
32 -QPDF_Array::QPDF_Array(OHArray const& items) : 32 +QPDF_Array::QPDF_Array(std::vector<std::shared_ptr<QPDFObject>> const& items) :
33 QPDFValue(::ot_array, "array"), 33 QPDFValue(::ot_array, "array"),
34 sparse(false), 34 sparse(false),
35 elements(items) 35 elements(items)
@@ -56,7 +56,7 @@ QPDF_Array::create(SparseOHArray const&amp; items) @@ -56,7 +56,7 @@ QPDF_Array::create(SparseOHArray const&amp; items)
56 } 56 }
57 57
58 std::shared_ptr<QPDFObject> 58 std::shared_ptr<QPDFObject>
59 -QPDF_Array::create(OHArray const& items) 59 +QPDF_Array::create(std::vector<std::shared_ptr<QPDFObject>> const& items)
60 { 60 {
61 return do_create(new QPDF_Array(items)); 61 return do_create(new QPDF_Array(items));
62 } 62 }
@@ -70,10 +70,10 @@ QPDF_Array::copy(bool shallow) @@ -70,10 +70,10 @@ QPDF_Array::copy(bool shallow)
70 if (shallow) { 70 if (shallow) {
71 return create(elements); 71 return create(elements);
72 } else { 72 } else {
73 - OHArray result;  
74 - result.elements.reserve(elements.elements.size());  
75 - for (auto const& element: elements.elements) {  
76 - result.elements.push_back( 73 + std::vector<std::shared_ptr<QPDFObject>> result;
  74 + result.reserve(elements.size());
  75 + for (auto const& element: elements) {
  76 + result.push_back(
77 element 77 element
78 ? (element->getObjGen().isIndirect() ? element 78 ? (element->getObjGen().isIndirect() ? element
79 : element->copy()) 79 : element->copy())
@@ -90,7 +90,7 @@ QPDF_Array::disconnect() @@ -90,7 +90,7 @@ QPDF_Array::disconnect()
90 if (sparse) { 90 if (sparse) {
91 sp_elements.disconnect(); 91 sp_elements.disconnect();
92 } else { 92 } else {
93 - for (auto const& iter: elements.elements) { 93 + for (auto const& iter: elements) {
94 if (iter) { 94 if (iter) {
95 QPDFObjectHandle::DisconnectAccess::disconnect(iter); 95 QPDFObjectHandle::DisconnectAccess::disconnect(iter);
96 } 96 }
@@ -112,7 +112,7 @@ QPDF_Array::unparse() @@ -112,7 +112,7 @@ QPDF_Array::unparse()
112 return result; 112 return result;
113 } else { 113 } else {
114 std::string result = "[ "; 114 std::string result = "[ ";
115 - auto size = elements.elements.size(); 115 + auto size = elements.size();
116 for (int i = 0; i < int(size); ++i) { 116 for (int i = 0; i < int(size); ++i) {
117 result += getItem(i).unparse(); 117 result += getItem(i).unparse();
118 result += " "; 118 result += " ";
@@ -134,7 +134,7 @@ QPDF_Array::getJSON(int json_version) @@ -134,7 +134,7 @@ QPDF_Array::getJSON(int json_version)
134 return j; 134 return j;
135 } else { 135 } else {
136 JSON j = JSON::makeArray(); 136 JSON j = JSON::makeArray();
137 - size_t size = elements.elements.size(); 137 + size_t size = elements.size();
138 for (int i = 0; i < int(size); ++i) { 138 for (int i = 0; i < int(size); ++i) {
139 j.addArrayElement(getItem(i).getJSON(json_version)); 139 j.addArrayElement(getItem(i).getJSON(json_version));
140 } 140 }
@@ -150,7 +150,7 @@ QPDF_Array::getNItems() const @@ -150,7 +150,7 @@ QPDF_Array::getNItems() const
150 // a lot of code. 150 // a lot of code.
151 return QIntC::to_int(sp_elements.size()); 151 return QIntC::to_int(sp_elements.size());
152 } else { 152 } else {
153 - return QIntC::to_int(elements.elements.size()); 153 + return QIntC::to_int(elements.size());
154 } 154 }
155 } 155 }
156 156
@@ -164,11 +164,11 @@ QPDF_Array::getItem(int n) const @@ -164,11 +164,11 @@ QPDF_Array::getItem(int n) const
164 } 164 }
165 return sp_elements.at(QIntC::to_size(n)); 165 return sp_elements.at(QIntC::to_size(n));
166 } else { 166 } else {
167 - if ((n < 0) || (n >= QIntC::to_int(elements.elements.size()))) { 167 + if ((n < 0) || (n >= QIntC::to_int(elements.size()))) {
168 throw std::logic_error( 168 throw std::logic_error(
169 "INTERNAL ERROR: bounds error accessing QPDF_Array element"); 169 "INTERNAL ERROR: bounds error accessing QPDF_Array element");
170 } 170 }
171 - auto const& obj = elements.elements.at(size_t(n)); 171 + auto const& obj = elements.at(size_t(n));
172 return obj ? obj : null_oh; 172 return obj ? obj : null_oh;
173 } 173 }
174 } 174 }
@@ -182,8 +182,7 @@ QPDF_Array::getAsVector(std::vector&lt;QPDFObjectHandle&gt;&amp; v) const @@ -182,8 +182,7 @@ QPDF_Array::getAsVector(std::vector&lt;QPDFObjectHandle&gt;&amp; v) const
182 v.push_back(sp_elements.at(i)); 182 v.push_back(sp_elements.at(i));
183 } 183 }
184 } else { 184 } else {
185 - v = std::vector<QPDFObjectHandle>(  
186 - elements.elements.cbegin(), elements.elements.cend()); 185 + v = std::vector<QPDFObjectHandle>(elements.cbegin(), elements.cend());
187 } 186 }
188 } 187 }
189 188
@@ -194,10 +193,10 @@ QPDF_Array::setItem(int n, QPDFObjectHandle const&amp; oh) @@ -194,10 +193,10 @@ QPDF_Array::setItem(int n, QPDFObjectHandle const&amp; oh)
194 sp_elements.setAt(QIntC::to_size(n), oh); 193 sp_elements.setAt(QIntC::to_size(n), oh);
195 } else { 194 } else {
196 size_t idx = size_t(n); 195 size_t idx = size_t(n);
197 - if (n < 0 || idx >= elements.elements.size()) { 196 + if (n < 0 || idx >= elements.size()) {
198 throw std::logic_error("bounds error setting item in QPDF_Array"); 197 throw std::logic_error("bounds error setting item in QPDF_Array");
199 } 198 }
200 - elements.elements[idx] = oh.getObj(); 199 + elements[idx] = oh.getObj();
201 } 200 }
202 } 201 }
203 202
@@ -210,9 +209,9 @@ QPDF_Array::setFromVector(std::vector&lt;QPDFObjectHandle&gt; const&amp; v) @@ -210,9 +209,9 @@ QPDF_Array::setFromVector(std::vector&lt;QPDFObjectHandle&gt; const&amp; v)
210 sp_elements.append(iter); 209 sp_elements.append(iter);
211 } 210 }
212 } else { 211 } else {
213 - elements = OHArray(); 212 + elements.resize(0);
214 for (auto const& iter: v) { 213 for (auto const& iter: v) {
215 - elements.elements.push_back(iter.getObj()); 214 + elements.push_back(iter.getObj());
216 } 215 }
217 } 216 }
218 } 217 }
@@ -231,10 +230,7 @@ QPDF_Array::setFromVector(std::vector&lt;std::shared_ptr&lt;QPDFObject&gt;&gt;&amp;&amp; v) @@ -231,10 +230,7 @@ QPDF_Array::setFromVector(std::vector&lt;std::shared_ptr&lt;QPDFObject&gt;&gt;&amp;&amp; v)
231 } 230 }
232 } 231 }
233 } else { 232 } else {
234 - elements = OHArray();  
235 - for (auto&& item: v) {  
236 - elements.elements.push_back(std::move(item));  
237 - } 233 + elements = std::move(v);
238 } 234 }
239 } 235 }
240 236
@@ -251,17 +247,16 @@ QPDF_Array::insertItem(int at, QPDFObjectHandle const&amp; item) @@ -251,17 +247,16 @@ QPDF_Array::insertItem(int at, QPDFObjectHandle const&amp; item)
251 } else { 247 } else {
252 // As special case, also allow insert beyond the end 248 // As special case, also allow insert beyond the end
253 size_t idx = QIntC::to_size(at); 249 size_t idx = QIntC::to_size(at);
254 - if ((at < 0) || (at > QIntC::to_int(elements.elements.size()))) { 250 + if ((at < 0) || (at > QIntC::to_int(elements.size()))) {
255 throw std::logic_error( 251 throw std::logic_error(
256 "INTERNAL ERROR: bounds error accessing QPDF_Array element"); 252 "INTERNAL ERROR: bounds error accessing QPDF_Array element");
257 } 253 }
258 - if (idx == elements.elements.size()) { 254 + if (idx == elements.size()) {
259 // Allow inserting to the last position 255 // Allow inserting to the last position
260 - elements.elements.push_back(item.getObj()); 256 + elements.push_back(item.getObj());
261 } else { 257 } else {
262 int n = int(idx); 258 int n = int(idx);
263 - elements.elements.insert(  
264 - elements.elements.cbegin() + n, item.getObj()); 259 + elements.insert(elements.cbegin() + n, item.getObj());
265 } 260 }
266 } 261 }
267 } 262 }
@@ -272,7 +267,7 @@ QPDF_Array::appendItem(QPDFObjectHandle const&amp; item) @@ -272,7 +267,7 @@ QPDF_Array::appendItem(QPDFObjectHandle const&amp; item)
272 if (sparse) { 267 if (sparse) {
273 sp_elements.append(item); 268 sp_elements.append(item);
274 } else { 269 } else {
275 - elements.elements.push_back(item.getObj()); 270 + elements.push_back(item.getObj());
276 } 271 }
277 } 272 }
278 273
@@ -283,10 +278,10 @@ QPDF_Array::eraseItem(int at) @@ -283,10 +278,10 @@ QPDF_Array::eraseItem(int at)
283 sp_elements.erase(QIntC::to_size(at)); 278 sp_elements.erase(QIntC::to_size(at));
284 } else { 279 } else {
285 size_t idx = QIntC::to_size(at); 280 size_t idx = QIntC::to_size(at);
286 - if (idx >= elements.elements.size()) { 281 + if (idx >= elements.size()) {
287 throw std::logic_error("bounds error erasing item from OHArray"); 282 throw std::logic_error("bounds error erasing item from OHArray");
288 } 283 }
289 int n = int(idx); 284 int n = int(idx);
290 - elements.elements.erase(elements.elements.cbegin() + n); 285 + elements.erase(elements.cbegin() + n);
291 } 286 }
292 } 287 }
libqpdf/qpdf/OHArray.hh deleted
1 -#ifndef QPDF_OHARRAY_HH  
2 -#define QPDF_OHARRAY_HH  
3 -  
4 -#include <qpdf/QPDFObjectHandle.hh>  
5 -#include <qpdf/QPDFObject_private.hh>  
6 -  
7 -#include <vector>  
8 -  
9 -class QPDF_Array;  
10 -  
11 -class OHArray  
12 -{  
13 - public:  
14 - OHArray();  
15 -  
16 - private:  
17 - friend class QPDF_Array;  
18 - std::vector<std::shared_ptr<QPDFObject>> elements;  
19 -};  
20 -  
21 -#endif // QPDF_OHARRAY_HH  
libqpdf/qpdf/QPDF_Array.hh
@@ -3,9 +3,7 @@ @@ -3,9 +3,7 @@
3 3
4 #include <qpdf/QPDFValue.hh> 4 #include <qpdf/QPDFValue.hh>
5 5
6 -#include <qpdf/OHArray.hh>  
7 #include <qpdf/SparseOHArray.hh> 6 #include <qpdf/SparseOHArray.hh>
8 -#include <list>  
9 #include <vector> 7 #include <vector>
10 8
11 class QPDF_Array: public QPDFValue 9 class QPDF_Array: public QPDFValue
@@ -17,7 +15,8 @@ class QPDF_Array: public QPDFValue @@ -17,7 +15,8 @@ class QPDF_Array: public QPDFValue
17 static std::shared_ptr<QPDFObject> 15 static std::shared_ptr<QPDFObject>
18 create(std::vector<std::shared_ptr<QPDFObject>>&& items, bool sparse); 16 create(std::vector<std::shared_ptr<QPDFObject>>&& items, bool sparse);
19 static std::shared_ptr<QPDFObject> create(SparseOHArray const& items); 17 static std::shared_ptr<QPDFObject> create(SparseOHArray const& items);
20 - static std::shared_ptr<QPDFObject> create(OHArray const& items); 18 + static std::shared_ptr<QPDFObject>
  19 + create(std::vector<std::shared_ptr<QPDFObject>> const& items);
21 virtual std::shared_ptr<QPDFObject> copy(bool shallow = false); 20 virtual std::shared_ptr<QPDFObject> copy(bool shallow = false);
22 virtual std::string unparse(); 21 virtual std::string unparse();
23 virtual JSON getJSON(int json_version); 22 virtual JSON getJSON(int json_version);
@@ -38,10 +37,10 @@ class QPDF_Array: public QPDFValue @@ -38,10 +37,10 @@ class QPDF_Array: public QPDFValue
38 QPDF_Array(std::vector<QPDFObjectHandle> const& items); 37 QPDF_Array(std::vector<QPDFObjectHandle> const& items);
39 QPDF_Array(std::vector<std::shared_ptr<QPDFObject>>&& items, bool sparse); 38 QPDF_Array(std::vector<std::shared_ptr<QPDFObject>>&& items, bool sparse);
40 QPDF_Array(SparseOHArray const& items); 39 QPDF_Array(SparseOHArray const& items);
41 - QPDF_Array(OHArray const& items); 40 + QPDF_Array(std::vector<std::shared_ptr<QPDFObject>> const& items);
42 bool sparse{false}; 41 bool sparse{false};
43 SparseOHArray sp_elements; 42 SparseOHArray sp_elements;
44 - OHArray elements; 43 + std::vector<std::shared_ptr<QPDFObject>> elements;
45 }; 44 };
46 45
47 #endif // QPDF_ARRAY_HH 46 #endif // QPDF_ARRAY_HH