2
1
mirror of https://github.com/qpdf/qpdf.git synced 2025-01-03 07:12:28 +00:00

Remove QPDFObject::object_type_e as alias for qpdf_object_type_e

This commit is contained in:
Jay Berkenbilt 2022-09-01 17:39:52 -04:00
parent a47b99953f
commit b663926538
8 changed files with 46 additions and 59 deletions

View File

@ -1,5 +1,9 @@
2022-09-01 Jay Berkenbilt <ejb@ql.org> 2022-09-01 Jay Berkenbilt <ejb@ql.org>
* Remove QPDFObject.hh from include/qpdf. The only reason to
include was to get QPDFObject::object_type_e. Instead, include
qpdf/Constants.h, and change `QPDFObject::ot_` to `::ot_`.
* More optimizations and cleanup from m-holger (#726, #730) * More optimizations and cleanup from m-holger (#726, #730)
including major refactor of QPDF's internal representations of including major refactor of QPDF's internal representations of
objects. In addition to a large performance improvement, this also objects. In addition to a large performance improvement, this also

View File

@ -61,9 +61,8 @@ enum qpdf_error_code_e {
* may be added to the list, so code that switches on these values * may be added to the list, so code that switches on these values
* should take that into consideration. (Maintainer note: it would be * should take that into consideration. (Maintainer note: it would be
* better to call this qpdf_ot_* rather than ot_* to reduce likelihood * better to call this qpdf_ot_* rather than ot_* to reduce likelihood
* of name collision, but since QPDFObject::object_type_e is an alias * of name collision, but changing the names of the values breaks
* to this type, changing the names of the values breaks backward * backward compatibility.)
* compatibility.)
*/ */
enum qpdf_object_type_e { enum qpdf_object_type_e {
/* Object types internal to qpdf */ /* Object types internal to qpdf */
@ -84,7 +83,6 @@ enum qpdf_object_type_e {
ot_inlineimage, ot_inlineimage,
/* Object types internal to qpdf */ /* Object types internal to qpdf */
ot_unresolved, ot_unresolved,
/* NOTE: if adding to this list, update QPDFObject.hh */
}; };
/* Write Parameters. See QPDFWriter.hh for details. */ /* Write Parameters. See QPDFWriter.hh for details. */

View File

@ -38,32 +38,6 @@ class QPDFObject
friend class QPDFValue; friend class QPDFValue;
public: public:
// Objects derived from QPDFObject are accessible through
// QPDFObjectHandle. Each object returns a unique type code that
// has one of the valid qpdf_object_type_e values. As new object
// types are added to qpdf, additional items may be added to the
// list, so code that switches on these values should take that
// into consideration.
// Prior to qpdf 10.5, qpdf_object_type_e was
// QPDFObject::object_type_e but was moved to make it accessible
// to the C API. The code below is for backward compatibility.
typedef enum qpdf_object_type_e object_type_e;
static constexpr object_type_e ot_uninitialized = ::ot_uninitialized;
static constexpr object_type_e ot_reserved = ::ot_reserved;
static constexpr object_type_e ot_null = ::ot_null;
static constexpr object_type_e ot_boolean = ::ot_boolean;
static constexpr object_type_e ot_integer = ::ot_integer;
static constexpr object_type_e ot_real = ::ot_real;
static constexpr object_type_e ot_string = ::ot_string;
static constexpr object_type_e ot_name = ::ot_name;
static constexpr object_type_e ot_array = ::ot_array;
static constexpr object_type_e ot_dictionary = ::ot_dictionary;
static constexpr object_type_e ot_stream = ::ot_stream;
static constexpr object_type_e ot_operator = ::ot_operator;
static constexpr object_type_e ot_inlineimage = ::ot_inlineimage;
static constexpr object_type_e ot_unresolved = ::ot_unresolved;
QPDFObject() = default; QPDFObject() = default;
virtual ~QPDFObject() = default; virtual ~QPDFObject() = default;
@ -84,7 +58,7 @@ class QPDFObject
} }
// Return a unique type code for the object // Return a unique type code for the object
object_type_e qpdf_object_type_e
getTypeCode() const getTypeCode() const
{ {
return value->type_code; return value->type_code;

View File

@ -338,7 +338,7 @@ class QPDFObjectHandle
// useful for doing rapid type tests (like switch statements) or // useful for doing rapid type tests (like switch statements) or
// for testing and debugging. // for testing and debugging.
QPDF_DLL QPDF_DLL
QPDFObject::object_type_e getTypeCode(); qpdf_object_type_e getTypeCode();
QPDF_DLL QPDF_DLL
char const* getTypeName(); char const* getTypeName();

View File

@ -251,11 +251,10 @@ QPDFObjectHandle::releaseResolved()
} }
} }
QPDFObject::object_type_e qpdf_object_type_e
QPDFObjectHandle::getTypeCode() QPDFObjectHandle::getTypeCode()
{ {
return dereference() ? this->obj->getTypeCode() return dereference() ? this->obj->getTypeCode() : ::ot_uninitialized;
: QPDFObject::ot_uninitialized;
} }
char const* char const*
@ -347,7 +346,7 @@ QPDFObjectHandle::asString()
bool bool
QPDFObjectHandle::isBool() QPDFObjectHandle::isBool()
{ {
return dereference() && (obj->getTypeCode() == QPDFObject::ot_boolean); return dereference() && (obj->getTypeCode() == ::ot_boolean);
} }
bool bool
@ -357,25 +356,25 @@ QPDFObjectHandle::isDirectNull() const
// objid == 0, so there's nothing to resolve. // objid == 0, so there's nothing to resolve.
return ( return (
isInitialized() && (getObjectID() == 0) && isInitialized() && (getObjectID() == 0) &&
(obj->getTypeCode() == QPDFObject::ot_null)); (obj->getTypeCode() == ::ot_null));
} }
bool bool
QPDFObjectHandle::isNull() QPDFObjectHandle::isNull()
{ {
return dereference() && (obj->getTypeCode() == QPDFObject::ot_null); return dereference() && (obj->getTypeCode() == ::ot_null);
} }
bool bool
QPDFObjectHandle::isInteger() QPDFObjectHandle::isInteger()
{ {
return dereference() && (obj->getTypeCode() == QPDFObject::ot_integer); return dereference() && (obj->getTypeCode() == ::ot_integer);
} }
bool bool
QPDFObjectHandle::isReal() QPDFObjectHandle::isReal()
{ {
return dereference() && (obj->getTypeCode() == QPDFObject::ot_real); return dereference() && (obj->getTypeCode() == ::ot_real);
} }
bool bool
@ -412,49 +411,49 @@ QPDFObjectHandle::getValueAsNumber(double& value)
bool bool
QPDFObjectHandle::isName() QPDFObjectHandle::isName()
{ {
return dereference() && (obj->getTypeCode() == QPDFObject::ot_name); return dereference() && (obj->getTypeCode() == ::ot_name);
} }
bool bool
QPDFObjectHandle::isString() QPDFObjectHandle::isString()
{ {
return dereference() && (obj->getTypeCode() == QPDFObject::ot_string); return dereference() && (obj->getTypeCode() == ::ot_string);
} }
bool bool
QPDFObjectHandle::isOperator() QPDFObjectHandle::isOperator()
{ {
return dereference() && (obj->getTypeCode() == QPDFObject::ot_operator); return dereference() && (obj->getTypeCode() == ::ot_operator);
} }
bool bool
QPDFObjectHandle::isInlineImage() QPDFObjectHandle::isInlineImage()
{ {
return dereference() && (obj->getTypeCode() == QPDFObject::ot_inlineimage); return dereference() && (obj->getTypeCode() == ::ot_inlineimage);
} }
bool bool
QPDFObjectHandle::isArray() QPDFObjectHandle::isArray()
{ {
return dereference() && (obj->getTypeCode() == QPDFObject::ot_array); return dereference() && (obj->getTypeCode() == ::ot_array);
} }
bool bool
QPDFObjectHandle::isDictionary() QPDFObjectHandle::isDictionary()
{ {
return dereference() && (obj->getTypeCode() == QPDFObject::ot_dictionary); return dereference() && (obj->getTypeCode() == ::ot_dictionary);
} }
bool bool
QPDFObjectHandle::isStream() QPDFObjectHandle::isStream()
{ {
return dereference() && (obj->getTypeCode() == QPDFObject::ot_stream); return dereference() && (obj->getTypeCode() == ::ot_stream);
} }
bool bool
QPDFObjectHandle::isReserved() QPDFObjectHandle::isReserved()
{ {
return dereference() && (obj->getTypeCode() == QPDFObject::ot_reserved); return dereference() && (obj->getTypeCode() == ::ot_reserved);
} }
bool bool

View File

@ -95,6 +95,18 @@ For a detailed list of changes, please see the file
- API: breaking changes - API: breaking changes
- Remove ``QPDFObject.hh`` from the public ``include/qpdf``
directory. The only use case for including
``qpdf/QPDFObject.hh`` was to get ``QPDFObject::object_type_e``.
Since 10.5.0, this has been an alias to ``qpdf_object_type_e``,
defined in ``qpdf/Constants.h``. To fix your code, replace any
includes of ``qpdf/QPDFObject.hh`` with ``qpdf/Constants.h``,
and replace all occurrences of ``QPDFObject::ot_`` with
``::ot_``. If you need your code to be backward compatible to
qpdf versions prior to 10.5.0, you can check that the
preprocessor symbol ``QPDF_MAJOR_VERSION`` is defined and ``>=
11``.
- Pipeline::write now takes ``unsigned char const*`` instead of - Pipeline::write now takes ``unsigned char const*`` instead of
``unsigned char*``. Callers don't need to change anything, but ``unsigned char*``. Callers don't need to change anything, but
you no longer have to pass writable pointers to pipelines. If you no longer have to pass writable pointers to pipelines. If

View File

@ -103,7 +103,7 @@ ParserCallbacks::handleObject(
<< ", length=" << length << ": "; << ", length=" << length << ": ";
if (obj.isInlineImage()) { if (obj.isInlineImage()) {
// Exercise getTypeCode // Exercise getTypeCode
assert(obj.getTypeCode() == QPDFObject::ot_inlineimage); assert(obj.getTypeCode() == ::ot_inlineimage);
std::cout << QUtil::hex_encode(obj.getInlineImageValue()) << std::endl; std::cout << QUtil::hex_encode(obj.getInlineImageValue()) << std::endl;
} else { } else {
std::cout << obj.unparse() << std::endl; std::cout << obj.unparse() << std::endl;
@ -3296,7 +3296,7 @@ runtest(int n, char const* filename1, char const* arg2)
assert(password == "1234567890123456789012(45678"); assert(password == "1234567890123456789012(45678");
QPDFObjectHandle uninitialized; QPDFObjectHandle uninitialized;
assert(uninitialized.getTypeCode() == QPDFObject::ot_uninitialized); assert(uninitialized.getTypeCode() == ::ot_uninitialized);
assert(strcmp(uninitialized.getTypeName(), "uninitialized") == 0); assert(strcmp(uninitialized.getTypeName(), "uninitialized") == 0);
} }

View File

@ -40,37 +40,37 @@ compare(QPDFObjectHandle a, QPDFObjectHandle b)
} }
switch (a.getTypeCode()) { switch (a.getTypeCode()) {
case QPDFObject::ot_boolean: case ::ot_boolean:
if (a.getBoolValue() != b.getBoolValue()) { if (a.getBoolValue() != b.getBoolValue()) {
std::cerr << "different boolean" << std::endl; std::cerr << "different boolean" << std::endl;
return false; return false;
} }
break; break;
case QPDFObject::ot_integer: case ::ot_integer:
if (a.getIntValue() != b.getIntValue()) { if (a.getIntValue() != b.getIntValue()) {
std::cerr << "different integer" << std::endl; std::cerr << "different integer" << std::endl;
return false; return false;
} }
break; break;
case QPDFObject::ot_real: case ::ot_real:
if (a.getRealValue() != b.getRealValue()) { if (a.getRealValue() != b.getRealValue()) {
std::cerr << "different real" << std::endl; std::cerr << "different real" << std::endl;
return false; return false;
} }
break; break;
case QPDFObject::ot_string: case ::ot_string:
if (a.getStringValue() != b.getStringValue()) { if (a.getStringValue() != b.getStringValue()) {
std::cerr << "different string" << std::endl; std::cerr << "different string" << std::endl;
return false; return false;
} }
break; break;
case QPDFObject::ot_name: case ::ot_name:
if (a.getName() != b.getName()) { if (a.getName() != b.getName()) {
std::cerr << "different name" << std::endl; std::cerr << "different name" << std::endl;
return false; return false;
} }
break; break;
case QPDFObject::ot_array: case ::ot_array:
{ {
std::vector<QPDFObjectHandle> objs_a = a.getArrayAsVector(); std::vector<QPDFObjectHandle> objs_a = a.getArrayAsVector();
std::vector<QPDFObjectHandle> objs_b = b.getArrayAsVector(); std::vector<QPDFObjectHandle> objs_b = b.getArrayAsVector();
@ -88,7 +88,7 @@ compare(QPDFObjectHandle a, QPDFObjectHandle b)
} }
} }
break; break;
case QPDFObject::ot_dictionary: case ::ot_dictionary:
{ {
std::set<std::string> keys_a = a.getKeys(); std::set<std::string> keys_a = a.getKeys();
std::set<std::string> keys_b = b.getKeys(); std::set<std::string> keys_b = b.getKeys();
@ -105,9 +105,9 @@ compare(QPDFObjectHandle a, QPDFObjectHandle b)
} }
} }
break; break;
case QPDFObject::ot_null: case ::ot_null:
break; break;
case QPDFObject::ot_stream: case ::ot_stream:
std::cout << "stream objects are not compared" << std::endl; std::cout << "stream objects are not compared" << std::endl;
break; break;
default: default: