Spaces:
Running
Running
//======================================================================== | |
// | |
// Array.h | |
// | |
// Copyright 1996-2003 Glyph & Cog, LLC | |
// | |
//======================================================================== | |
//======================================================================== | |
// | |
// Modified under the Poppler project - http://poppler.freedesktop.org | |
// | |
// All changes made under the Poppler project to this file are licensed | |
// under GPL version 2 or later | |
// | |
// Copyright (C) 2005 Kristian Høgsberg <[email protected]> | |
// Copyright (C) 2012 Fabio D'Urso <[email protected]> | |
// Copyright (C) 2013 Thomas Freitag <[email protected]> | |
// Copyright (C) 2017-2019, 2021 Albert Astals Cid <[email protected]> | |
// Copyright (C) 2017 Adrian Johnson <[email protected]> | |
// Copyright (C) 2018, 2019 Adam Reichold <[email protected]> | |
// | |
// To see a description of the changes please see the Changelog file that | |
// came with your tarball or type make ChangeLog if you are building from git | |
// | |
//======================================================================== | |
class XRef; | |
//------------------------------------------------------------------------ | |
// Array | |
//------------------------------------------------------------------------ | |
class POPPLER_PRIVATE_EXPORT Array | |
{ | |
public: | |
// Constructor. | |
explicit Array(XRef *xrefA); | |
// Destructor. | |
~Array(); | |
Array(const Array &) = delete; | |
Array &operator=(const Array &) = delete; | |
// Get number of elements. | |
int getLength() const { return elems.size(); } | |
// Copy array with new xref | |
Array *copy(XRef *xrefA) const; | |
Array *deepCopy() const; | |
// Add an element | |
// elem becomes a dead object after this call | |
void add(Object &&elem); | |
// Remove an element by position | |
void remove(int i); | |
// Accessors. | |
Object get(int i, int recursion = 0) const; | |
// Same as above but if the returned object is a fetched Ref returns such Ref in returnRef, otherwise returnRef is Ref::INVALID() | |
Object get(int i, Ref *returnRef, int recursion = 0) const; | |
const Object &getNF(int i) const; | |
bool getString(int i, GooString *string) const; | |
private: | |
friend class Object; // for incRef/decRef | |
// Reference counting. | |
int incRef() { return ++ref; } | |
int decRef() { return --ref; } | |
XRef *xref; // the xref table for this PDF file | |
std::vector<Object> elems; // array of elements | |
std::atomic_int ref; // reference count | |
mutable std::recursive_mutex mutex; | |
}; | |