mirror of
https://github.com/qpdf/qpdf.git
synced 2025-01-05 08:02:11 +00:00
Make object types available to C API
This commit is contained in:
parent
cce715cd0e
commit
c40f8b5329
@ -1,5 +1,9 @@
|
|||||||
2021-12-17 Jay Berkenbilt <ejb@ql.org>
|
2021-12-17 Jay Berkenbilt <ejb@ql.org>
|
||||||
|
|
||||||
|
* QPDFObjectHandle object types have been moved from
|
||||||
|
QPDFObject::object_type_e to qpdf_object_type_e (defined in
|
||||||
|
Constants.h). Old values are available for backward compatibility.
|
||||||
|
|
||||||
* Add Pl_Buffer::getMallocBuffer() to initialize a buffer with
|
* Add Pl_Buffer::getMallocBuffer() to initialize a buffer with
|
||||||
malloc in support of the C API
|
malloc in support of the C API
|
||||||
|
|
||||||
|
@ -41,6 +41,34 @@ enum qpdf_error_code_e
|
|||||||
qpdf_e_object, /* type/bounds errors accessing objects */
|
qpdf_e_object, /* type/bounds errors accessing objects */
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/* Object Types */
|
||||||
|
|
||||||
|
/* PDF objects represented by QPDFObjectHandle or, in the C API, by
|
||||||
|
* qpdf_oh, have a unique type code that has one of the values in the
|
||||||
|
* list below. 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.
|
||||||
|
*/
|
||||||
|
enum qpdf_object_type_e {
|
||||||
|
/* Object types internal to qpdf */
|
||||||
|
qpdf_ot_uninitialized,
|
||||||
|
qpdf_ot_reserved,
|
||||||
|
/* Object types that can occur in the main document */
|
||||||
|
qpdf_ot_null,
|
||||||
|
qpdf_ot_boolean,
|
||||||
|
qpdf_ot_integer,
|
||||||
|
qpdf_ot_real,
|
||||||
|
qpdf_ot_string,
|
||||||
|
qpdf_ot_name,
|
||||||
|
qpdf_ot_array,
|
||||||
|
qpdf_ot_dictionary,
|
||||||
|
qpdf_ot_stream,
|
||||||
|
/* Additional object types that can occur in content streams */
|
||||||
|
qpdf_ot_operator,
|
||||||
|
qpdf_ot_inlineimage,
|
||||||
|
/* NOTE: if adding to this list, update QPDFObject.hh */
|
||||||
|
};
|
||||||
|
|
||||||
/* Write Parameters. See QPDFWriter.hh for details. */
|
/* Write Parameters. See QPDFWriter.hh for details. */
|
||||||
|
|
||||||
enum qpdf_object_stream_e
|
enum qpdf_object_stream_e
|
||||||
|
@ -25,6 +25,7 @@
|
|||||||
#include <qpdf/DLL.h>
|
#include <qpdf/DLL.h>
|
||||||
#include <qpdf/Types.h>
|
#include <qpdf/Types.h>
|
||||||
#include <qpdf/JSON.hh>
|
#include <qpdf/JSON.hh>
|
||||||
|
#include <qpdf/Constants.h>
|
||||||
|
|
||||||
#include <string>
|
#include <string>
|
||||||
|
|
||||||
@ -38,28 +39,28 @@ class QPDF_DLL_CLASS QPDFObject
|
|||||||
|
|
||||||
// Objects derived from QPDFObject are accessible through
|
// Objects derived from QPDFObject are accessible through
|
||||||
// QPDFObjectHandle. Each object returns a unique type code that
|
// QPDFObjectHandle. Each object returns a unique type code that
|
||||||
// has one of the values in the list below. As new object types
|
// has one of the valid qpdf_object_type_e values. As new object
|
||||||
// are added to qpdf, additional items may be added to the list,
|
// types are added to qpdf, additional items may be added to the
|
||||||
// so code that switches on these values should take that into
|
// list, so code that switches on these values should take that
|
||||||
// consideration.
|
// into consideration.
|
||||||
enum object_type_e {
|
|
||||||
// Object types internal to qpdf
|
// Prior to qpdf 10.5, qpdf_object_type_e was
|
||||||
ot_uninitialized,
|
// QPDFObject::object_type_e but was moved to make it accessible
|
||||||
ot_reserved,
|
// to the C API. The code below is for backward compatibility.
|
||||||
// Object types that can occur in the main document
|
typedef enum qpdf_object_type_e object_type_e;
|
||||||
ot_null,
|
static constexpr object_type_e ot_uninitialized = ::qpdf_ot_uninitialized;
|
||||||
ot_boolean,
|
static constexpr object_type_e ot_reserved = ::qpdf_ot_reserved;
|
||||||
ot_integer,
|
static constexpr object_type_e ot_null = ::qpdf_ot_null;
|
||||||
ot_real,
|
static constexpr object_type_e ot_boolean = ::qpdf_ot_boolean;
|
||||||
ot_string,
|
static constexpr object_type_e ot_integer = ::qpdf_ot_integer;
|
||||||
ot_name,
|
static constexpr object_type_e ot_real = ::qpdf_ot_real;
|
||||||
ot_array,
|
static constexpr object_type_e ot_string = ::qpdf_ot_string;
|
||||||
ot_dictionary,
|
static constexpr object_type_e ot_name = ::qpdf_ot_name;
|
||||||
ot_stream,
|
static constexpr object_type_e ot_array = ::qpdf_ot_array;
|
||||||
// Additional object types that can occur in content streams
|
static constexpr object_type_e ot_dictionary = ::qpdf_ot_dictionary;
|
||||||
ot_operator,
|
static constexpr object_type_e ot_stream = ::qpdf_ot_stream;
|
||||||
ot_inlineimage,
|
static constexpr object_type_e ot_operator = ::qpdf_ot_operator;
|
||||||
};
|
static constexpr object_type_e ot_inlineimage = ::qpdf_ot_inlineimage;
|
||||||
|
|
||||||
virtual ~QPDFObject() {}
|
virtual ~QPDFObject() {}
|
||||||
virtual std::string unparse() = 0;
|
virtual std::string unparse() = 0;
|
||||||
|
Loading…
Reference in New Issue
Block a user