mirror of
https://github.com/qpdf/qpdf.git
synced 2024-12-31 14:01:59 +00:00
In FUTURE make QPDFObjectHandle methods const and noexcept where possible
This commit is contained in:
parent
f49f43fed1
commit
6ad16cd1fd
@ -1371,12 +1371,12 @@ class QPDFObjectHandle
|
||||
QPDF_Real* asReal() const;
|
||||
QPDF_Reserved* asReserved() const;
|
||||
QPDF_Stream* asStream() const;
|
||||
QPDF_Stream* asStreamWithAssert();
|
||||
QPDF_Stream* asStreamWithAssert() const;
|
||||
QPDF_String* asString() const;
|
||||
|
||||
void typeWarning(char const* expected_type, std::string const& warning);
|
||||
void objectWarning(std::string const& warning);
|
||||
void assertType(char const* type_name, bool istype);
|
||||
void typeWarning(char const* expected_type, std::string const& warning) const;
|
||||
void objectWarning(std::string const& warning) const;
|
||||
void assertType(char const* type_name, bool istype) const;
|
||||
void makeDirect(QPDFObjGen::set& visited, bool stop_at_streams);
|
||||
void disconnect();
|
||||
void setParsedOffset(qpdf_offset_t offset);
|
||||
|
@ -296,48 +296,48 @@ class QPDFObjectHandle
|
||||
QPDFObjectHandle& operator=(QPDFObjectHandle&&) = default;
|
||||
|
||||
QPDF_DLL
|
||||
inline bool isInitialized() const;
|
||||
inline bool isInitialized() const noexcept;
|
||||
|
||||
// This method returns true if the QPDFObjectHandle objects point to exactly the same underlying
|
||||
// object, meaning that changes to one are reflected in the other, or "if you paint one, the
|
||||
// other one changes color." This does not perform a structural comparison of the contents of
|
||||
// the objects.
|
||||
QPDF_DLL
|
||||
bool isSameObjectAs(QPDFObjectHandle const&) const;
|
||||
bool isSameObjectAs(QPDFObjectHandle const&) const noexcept;
|
||||
|
||||
// Return type code and type name of underlying object. These are useful for doing rapid type
|
||||
// tests (like switch statements) or for testing and debugging.
|
||||
QPDF_DLL
|
||||
qpdf_object_type_e getTypeCode();
|
||||
qpdf_object_type_e getTypeCode() const;
|
||||
QPDF_DLL
|
||||
char const* getTypeName();
|
||||
char const* getTypeName() const;
|
||||
|
||||
// Exactly one of these will return true for any initialized object. Operator and InlineImage
|
||||
// are only allowed in content streams.
|
||||
QPDF_DLL
|
||||
bool isBool();
|
||||
bool isBool() const;
|
||||
QPDF_DLL
|
||||
bool isNull();
|
||||
bool isNull() const;
|
||||
QPDF_DLL
|
||||
bool isInteger();
|
||||
bool isInteger() const;
|
||||
QPDF_DLL
|
||||
bool isReal();
|
||||
bool isReal() const;
|
||||
QPDF_DLL
|
||||
bool isName();
|
||||
bool isName() const;
|
||||
QPDF_DLL
|
||||
bool isString();
|
||||
bool isString() const;
|
||||
QPDF_DLL
|
||||
bool isOperator();
|
||||
bool isOperator() const;
|
||||
QPDF_DLL
|
||||
bool isInlineImage();
|
||||
bool isInlineImage() const;
|
||||
QPDF_DLL
|
||||
bool isArray();
|
||||
bool isArray() const;
|
||||
QPDF_DLL
|
||||
bool isDictionary();
|
||||
bool isDictionary() const;
|
||||
QPDF_DLL
|
||||
bool isStream();
|
||||
bool isStream() const;
|
||||
QPDF_DLL
|
||||
bool isReserved();
|
||||
bool isReserved() const;
|
||||
|
||||
// True for objects that are direct nulls. Does not attempt to resolve objects. This is intended
|
||||
// for internal use, but it can be used as an efficient way to check for nulls that are not
|
||||
@ -352,23 +352,23 @@ class QPDFObjectHandle
|
||||
// This returns true for indirect objects from a QPDF that has been destroyed. Trying unparse
|
||||
// such an object will throw a logic_error.
|
||||
QPDF_DLL
|
||||
bool isDestroyed();
|
||||
bool isDestroyed() const;
|
||||
|
||||
// True for everything except array, dictionary, stream, word, and inline image.
|
||||
QPDF_DLL
|
||||
bool isScalar();
|
||||
bool isScalar() const;
|
||||
|
||||
// True if the object is a name object representing the provided name.
|
||||
QPDF_DLL
|
||||
bool isNameAndEquals(std::string const& name);
|
||||
bool isNameAndEquals(std::string const& name) const;
|
||||
|
||||
// True if the object is a dictionary of the specified type and subtype, if any.
|
||||
QPDF_DLL
|
||||
bool isDictionaryOfType(std::string const& type, std::string const& subtype = "");
|
||||
bool isDictionaryOfType(std::string const& type, std::string const& subtype = "") const;
|
||||
|
||||
// True if the object is a stream of the specified type and subtype, if any.
|
||||
QPDF_DLL
|
||||
bool isStreamOfType(std::string const& type, std::string const& subtype = "");
|
||||
bool isStreamOfType(std::string const& type, std::string const& subtype = "") const;
|
||||
|
||||
// Public factory methods
|
||||
|
||||
@ -413,7 +413,7 @@ class QPDFObjectHandle
|
||||
// object was created without parsing. If the object is in a stream, the offset is from the
|
||||
// beginning of the stream. Otherwise, the offset is from the beginning of the file.
|
||||
QPDF_DLL
|
||||
qpdf_offset_t getParsedOffset();
|
||||
qpdf_offset_t getParsedOffset() const;
|
||||
|
||||
// Older method: stream_or_array should be the value of /Contents from a page object. It's more
|
||||
// convenient to just call QPDFPageObjectHelper::parsePageContents on the page object, and error
|
||||
@ -585,7 +585,7 @@ class QPDFObjectHandle
|
||||
QPDF_DLL
|
||||
void setObjectDescription(QPDF* owning_qpdf, std::string const& object_description);
|
||||
QPDF_DLL
|
||||
bool hasObjectDescription();
|
||||
bool hasObjectDescription() const;
|
||||
|
||||
// Accessor methods
|
||||
//
|
||||
@ -635,57 +635,57 @@ class QPDFObjectHandle
|
||||
|
||||
// Methods for bool objects
|
||||
QPDF_DLL
|
||||
bool getBoolValue();
|
||||
bool getBoolValue() const;
|
||||
QPDF_DLL
|
||||
bool getValueAsBool(bool&);
|
||||
bool getValueAsBool(bool&) const;
|
||||
|
||||
// Methods for integer objects. Note: if an integer value is too big (too far away from zero in
|
||||
// either direction) to fit in the requested return type, the maximum or minimum value for that
|
||||
// return type may be returned. For example, on a system with 32-bit int, a numeric object with
|
||||
// a value of 2^40 (or anything too big for 32 bits) will be returned as INT_MAX.
|
||||
QPDF_DLL
|
||||
long long getIntValue();
|
||||
long long getIntValue() const;
|
||||
QPDF_DLL
|
||||
bool getValueAsInt(long long&);
|
||||
bool getValueAsInt(long long&) const;
|
||||
QPDF_DLL
|
||||
int getIntValueAsInt();
|
||||
int getIntValueAsInt() const;
|
||||
QPDF_DLL
|
||||
bool getValueAsInt(int&);
|
||||
bool getValueAsInt(int&) const;
|
||||
QPDF_DLL
|
||||
unsigned long long getUIntValue();
|
||||
unsigned long long getUIntValue() const;
|
||||
QPDF_DLL
|
||||
bool getValueAsUInt(unsigned long long&);
|
||||
bool getValueAsUInt(unsigned long long&) const;
|
||||
QPDF_DLL
|
||||
unsigned int getUIntValueAsUInt();
|
||||
unsigned int getUIntValueAsUInt() const;
|
||||
QPDF_DLL
|
||||
bool getValueAsUInt(unsigned int&);
|
||||
bool getValueAsUInt(unsigned int&) const;
|
||||
|
||||
// Methods for real objects
|
||||
QPDF_DLL
|
||||
std::string getRealValue();
|
||||
std::string getRealValue() const;
|
||||
QPDF_DLL
|
||||
bool getValueAsReal(std::string&);
|
||||
bool getValueAsReal(std::string&) const;
|
||||
|
||||
// Methods that work for both integer and real objects
|
||||
QPDF_DLL
|
||||
bool isNumber();
|
||||
bool isNumber() const;
|
||||
QPDF_DLL
|
||||
double getNumericValue();
|
||||
double getNumericValue() const;
|
||||
QPDF_DLL
|
||||
bool getValueAsNumber(double&);
|
||||
bool getValueAsNumber(double&) const;
|
||||
|
||||
// Methods for name objects. The returned name value is in qpdf's canonical form with all
|
||||
// escaping resolved. See comments for newName() for details.
|
||||
QPDF_DLL
|
||||
std::string getName();
|
||||
std::string getName() const;
|
||||
QPDF_DLL
|
||||
bool getValueAsName(std::string&);
|
||||
bool getValueAsName(std::string&) const;
|
||||
|
||||
// Methods for string objects
|
||||
QPDF_DLL
|
||||
std::string getStringValue();
|
||||
std::string getStringValue() const;
|
||||
QPDF_DLL
|
||||
bool getValueAsString(std::string&);
|
||||
bool getValueAsString(std::string&) const;
|
||||
|
||||
// If a string starts with the UTF-16 marker, it is converted from UTF-16 to UTF-8. Otherwise,
|
||||
// it is treated as a string encoded with PDF Doc Encoding. PDF Doc Encoding is identical to
|
||||
@ -693,19 +693,19 @@ class QPDFObjectHandle
|
||||
// to Unicode. QPDF versions prior to version 8.0.0 erroneously left characters in that range
|
||||
// unmapped.
|
||||
QPDF_DLL
|
||||
std::string getUTF8Value();
|
||||
std::string getUTF8Value() const;
|
||||
QPDF_DLL
|
||||
bool getValueAsUTF8(std::string&);
|
||||
bool getValueAsUTF8(std::string&) const;
|
||||
|
||||
// Methods for content stream objects
|
||||
QPDF_DLL
|
||||
std::string getOperatorValue();
|
||||
std::string getOperatorValue() const;
|
||||
QPDF_DLL
|
||||
bool getValueAsOperator(std::string&);
|
||||
bool getValueAsOperator(std::string&) const;
|
||||
QPDF_DLL
|
||||
std::string getInlineImageValue();
|
||||
std::string getInlineImageValue() const;
|
||||
QPDF_DLL
|
||||
bool getValueAsInlineImage(std::string&);
|
||||
bool getValueAsInlineImage(std::string&) const;
|
||||
|
||||
// Methods for array objects; see also name and array objects.
|
||||
|
||||
@ -720,26 +720,26 @@ class QPDFObjectHandle
|
||||
QPDFArrayItems aitems();
|
||||
|
||||
QPDF_DLL
|
||||
int getArrayNItems();
|
||||
int getArrayNItems() const;
|
||||
QPDF_DLL
|
||||
QPDFObjectHandle getArrayItem(int n);
|
||||
QPDFObjectHandle getArrayItem(int n) const;
|
||||
// Note: QPDF arrays internally optimize memory for arrays containing lots of nulls. Calling
|
||||
// getArrayAsVector may cause a lot of memory to be allocated for very large arrays with lots of
|
||||
// nulls.
|
||||
QPDF_DLL
|
||||
std::vector<QPDFObjectHandle> getArrayAsVector();
|
||||
std::vector<QPDFObjectHandle> getArrayAsVector() const;
|
||||
QPDF_DLL
|
||||
bool isRectangle();
|
||||
bool isRectangle() const;
|
||||
// If the array is an array of four numeric values, return as a rectangle. Otherwise, return the
|
||||
// rectangle [0, 0, 0, 0]
|
||||
QPDF_DLL
|
||||
Rectangle getArrayAsRectangle();
|
||||
Rectangle getArrayAsRectangle() const;
|
||||
QPDF_DLL
|
||||
bool isMatrix();
|
||||
bool isMatrix() const;
|
||||
// If the array is an array of six numeric values, return as a matrix. Otherwise, return the
|
||||
// matrix [1, 0, 0, 1, 0, 0]
|
||||
QPDF_DLL
|
||||
Matrix getArrayAsMatrix();
|
||||
Matrix getArrayAsMatrix() const;
|
||||
|
||||
// Methods for dictionary objects. In all dictionary methods, keys are specified/represented as
|
||||
// canonical name strings starting with a leading slash and not containing any PDF syntax
|
||||
@ -759,27 +759,27 @@ class QPDFObjectHandle
|
||||
// Return true if key is present. Keys with null values are treated as if they are not present.
|
||||
// This is as per the PDF spec.
|
||||
QPDF_DLL
|
||||
bool hasKey(std::string const&);
|
||||
bool hasKey(std::string const&) const;
|
||||
// Return the value for the key. If the key is not present, null is returned.
|
||||
QPDF_DLL
|
||||
QPDFObjectHandle getKey(std::string const&);
|
||||
QPDFObjectHandle getKey(std::string const&) const;
|
||||
// If the object is null, return null. Otherwise, call getKey(). This makes it easier to access
|
||||
// lower-level dictionaries, as in
|
||||
// auto font = page.getKeyIfDict("/Resources").getKeyIfDict("/Font");
|
||||
QPDF_DLL
|
||||
QPDFObjectHandle getKeyIfDict(std::string const&);
|
||||
QPDFObjectHandle getKeyIfDict(std::string const&) const;
|
||||
// Return all keys. Keys with null values are treated as if they are not present. This is as
|
||||
// per the PDF spec.
|
||||
QPDF_DLL
|
||||
std::set<std::string> getKeys();
|
||||
std::set<std::string> getKeys() const;
|
||||
// Return dictionary as a map. Entries with null values are included.
|
||||
QPDF_DLL
|
||||
std::map<std::string, QPDFObjectHandle> getDictAsMap();
|
||||
std::map<std::string, QPDFObjectHandle> getDictAsMap() const;
|
||||
|
||||
// Methods for name and array objects. The name value is in qpdf's canonical form with all
|
||||
// escaping resolved. See comments for newName() for details.
|
||||
QPDF_DLL
|
||||
bool isOrHasName(std::string const&);
|
||||
bool isOrHasName(std::string const&) const;
|
||||
|
||||
// Make all resources in a resource dictionary indirect. This just goes through all entries of
|
||||
// top-level subdictionaries and converts any direct objects to indirect objects. This can be
|
||||
@ -829,7 +829,7 @@ class QPDFObjectHandle
|
||||
// method returns a set of all the keys in all top-level subdictionaries. For resources
|
||||
// dictionaries, this is the collection of names that may be referenced in the content stream.
|
||||
QPDF_DLL
|
||||
std::set<std::string> getResourceNames();
|
||||
std::set<std::string> getResourceNames() const;
|
||||
|
||||
// Find a unique name within a resource dictionary starting with a given prefix. This method
|
||||
// works by appending a number to the given prefix. It searches starting with min_suffix and
|
||||
@ -844,7 +844,7 @@ class QPDFObjectHandle
|
||||
std::string getUniqueResourceName(
|
||||
std::string const& prefix,
|
||||
int& min_suffix,
|
||||
std::set<std::string>* resource_names = nullptr);
|
||||
std::set<std::string>* resource_names = nullptr) const;
|
||||
|
||||
// A QPDFObjectHandle has an owning QPDF if it is associated with ("owned by") a specific QPDF
|
||||
// object. Indirect objects always have an owning QPDF. Direct objects that are read from the
|
||||
@ -964,7 +964,7 @@ class QPDFObjectHandle
|
||||
|
||||
// Methods for stream objects
|
||||
QPDF_DLL
|
||||
QPDFObjectHandle getDict();
|
||||
QPDFObjectHandle getDict() const;
|
||||
|
||||
// By default, or if true passed, QPDFWriter will attempt to filter a stream based on decode
|
||||
// level, whether compression is enabled, and its ability to filter. Passing false will prevent
|
||||
@ -1153,12 +1153,12 @@ class QPDFObjectHandle
|
||||
inline int getGeneration() const;
|
||||
|
||||
QPDF_DLL
|
||||
std::string unparse();
|
||||
std::string unparse() const;
|
||||
QPDF_DLL
|
||||
std::string unparseResolved();
|
||||
std::string unparseResolved() const;
|
||||
// For strings only, force binary representation. Otherwise, same as unparse.
|
||||
QPDF_DLL
|
||||
std::string unparseBinary();
|
||||
std::string unparseBinary() const;
|
||||
|
||||
// Return encoded as JSON. The constant JSON::LATEST can be used to specify the latest available
|
||||
// JSON version. The JSON is generated as follows:
|
||||
@ -1192,19 +1192,19 @@ class QPDFObjectHandle
|
||||
// the object. The effect of dereference_indirect applies only to this object. It is not
|
||||
// recursive.
|
||||
QPDF_DLL
|
||||
JSON getJSON(int json_version, bool dereference_indirect = false);
|
||||
JSON getJSON(int json_version, bool dereference_indirect = false) const;
|
||||
|
||||
// Write the object encoded as JSON to a pipeline. This is equivalent to, but more efficient
|
||||
// than, calling getJSON(json_version, dereference_indirect).write(p, depth). See the
|
||||
// documentation for getJSON and JSON::write for further detail.
|
||||
QPDF_DLL
|
||||
void
|
||||
writeJSON(int json_version, Pipeline* p, bool dereference_indirect = false, size_t depth = 0);
|
||||
void writeJSON(
|
||||
int json_version, Pipeline* p, bool dereference_indirect = false, size_t depth = 0) const;
|
||||
|
||||
// Deprecated version uses v1 for backward compatibility.
|
||||
// ABI: remove for qpdf 12
|
||||
[[deprecated("Use getJSON(int version)")]] QPDF_DLL JSON
|
||||
getJSON(bool dereference_indirect = false);
|
||||
getJSON(bool dereference_indirect = false) const;
|
||||
|
||||
// This method can be called on a stream to get a more extended JSON representation of the
|
||||
// stream that includes the stream's data. The JSON object returned is always a dictionary whose
|
||||
@ -1257,7 +1257,7 @@ class QPDFObjectHandle
|
||||
// normally from the file have descriptions. See comments on setObjectDescription for additional
|
||||
// details.
|
||||
QPDF_DLL
|
||||
void warnIfPossible(std::string const& warning);
|
||||
void warnIfPossible(std::string const& warning) const;
|
||||
|
||||
// Provide access to specific classes for recursive disconnected().
|
||||
class DisconnectAccess
|
||||
@ -1280,55 +1280,55 @@ class QPDFObjectHandle
|
||||
void assertInitialized() const;
|
||||
|
||||
QPDF_DLL
|
||||
void assertNull();
|
||||
void assertNull() const;
|
||||
QPDF_DLL
|
||||
void assertBool();
|
||||
void assertBool() const;
|
||||
QPDF_DLL
|
||||
void assertInteger();
|
||||
void assertInteger() const;
|
||||
QPDF_DLL
|
||||
void assertReal();
|
||||
void assertReal() const;
|
||||
QPDF_DLL
|
||||
void assertName();
|
||||
void assertName() const;
|
||||
QPDF_DLL
|
||||
void assertString();
|
||||
void assertString() const;
|
||||
QPDF_DLL
|
||||
void assertOperator();
|
||||
void assertOperator() const;
|
||||
QPDF_DLL
|
||||
void assertInlineImage();
|
||||
void assertInlineImage() const;
|
||||
QPDF_DLL
|
||||
void assertArray();
|
||||
void assertArray() const;
|
||||
QPDF_DLL
|
||||
void assertDictionary();
|
||||
void assertDictionary() const;
|
||||
QPDF_DLL
|
||||
void assertStream();
|
||||
void assertStream() const;
|
||||
QPDF_DLL
|
||||
void assertReserved();
|
||||
void assertReserved() const;
|
||||
|
||||
QPDF_DLL
|
||||
void assertIndirect();
|
||||
void assertIndirect() const;
|
||||
QPDF_DLL
|
||||
void assertScalar();
|
||||
void assertScalar() const;
|
||||
QPDF_DLL
|
||||
void assertNumber();
|
||||
void assertNumber() const;
|
||||
|
||||
// The isPageObject method checks the /Type key of the object. This is not completely reliable
|
||||
// as there are some otherwise valid files whose /Type is wrong for page objects. qpdf is
|
||||
// slightly more accepting but may still return false here when treating the object as a page
|
||||
// would work. Use this sparingly.
|
||||
QPDF_DLL
|
||||
bool isPageObject();
|
||||
bool isPageObject() const;
|
||||
QPDF_DLL
|
||||
bool isPagesObject();
|
||||
bool isPagesObject() const;
|
||||
QPDF_DLL
|
||||
void assertPageObject();
|
||||
void assertPageObject() const;
|
||||
|
||||
QPDF_DLL
|
||||
bool isFormXObject();
|
||||
bool isFormXObject() const;
|
||||
|
||||
// Indicate if this is an image. If exclude_imagemask is true, don't count image masks as
|
||||
// images.
|
||||
QPDF_DLL
|
||||
bool isImage(bool exclude_imagemask = true);
|
||||
bool isImage(bool exclude_imagemask = true) const;
|
||||
|
||||
// The following methods do not form part of the public API and are for internal use only.
|
||||
|
||||
@ -1357,7 +1357,7 @@ class QPDFObjectHandle
|
||||
return obj.get();
|
||||
}
|
||||
|
||||
void writeJSON(int json_version, JSON::Writer& p, bool dereference_indirect = false);
|
||||
void writeJSON(int json_version, JSON::Writer& p, bool dereference_indirect = false) const;
|
||||
|
||||
private:
|
||||
QPDF_Array* asArray() const;
|
||||
@ -1371,12 +1371,12 @@ class QPDFObjectHandle
|
||||
QPDF_Real* asReal() const;
|
||||
QPDF_Reserved* asReserved() const;
|
||||
QPDF_Stream* asStream() const;
|
||||
QPDF_Stream* asStreamWithAssert();
|
||||
QPDF_Stream* asStreamWithAssert() const;
|
||||
QPDF_String* asString() const;
|
||||
|
||||
void typeWarning(char const* expected_type, std::string const& warning);
|
||||
void objectWarning(std::string const& warning);
|
||||
void assertType(char const* type_name, bool istype);
|
||||
void typeWarning(char const* expected_type, std::string const& warning) const;
|
||||
void objectWarning(std::string const& warning) const;
|
||||
void assertType(char const* type_name, bool istype) const;
|
||||
void makeDirect(QPDFObjGen::set& visited, bool stop_at_streams);
|
||||
void disconnect();
|
||||
void setParsedOffset(qpdf_offset_t offset);
|
||||
@ -1405,11 +1405,11 @@ class QPDFObjectHandle
|
||||
// from being here.
|
||||
|
||||
/* clang-format off */
|
||||
// Disable formatting for this declaration: emacs font-lock in cc-mode (as of 28.1) treats the rest
|
||||
// of the file as a string if clang-format removes the space after "operator", and as of
|
||||
// clang-format 15, there's no way to prevent it from doing so.
|
||||
QPDF_DLL
|
||||
QPDFObjectHandle operator ""_qpdf(char const* v, size_t len);
|
||||
// Disable formatting for this declaration: emacs font-lock in cc-mode (as of 28.1) treats the rest
|
||||
// of the file as a string if clang-format removes the space after "operator", and as of
|
||||
// clang-format 15, there's no way to prevent it from doing so.
|
||||
QPDF_DLL
|
||||
QPDFObjectHandle operator ""_qpdf(char const* v, size_t len);
|
||||
/* clang-format on */
|
||||
|
||||
#endif // QPDF_NO_QPDF_STRING
|
||||
@ -1629,7 +1629,7 @@ QPDFObjectHandle::isIndirect() const
|
||||
}
|
||||
|
||||
inline bool
|
||||
QPDFObjectHandle::isInitialized() const
|
||||
QPDFObjectHandle::isInitialized() const noexcept
|
||||
{
|
||||
return obj != nullptr;
|
||||
}
|
||||
|
File diff suppressed because it is too large
Load Diff
Loading…
Reference in New Issue
Block a user