diff options
author | Jay Berkenbilt <ejb@ql.org> | 2022-09-08 21:57:33 +0200 |
---|---|---|
committer | Jay Berkenbilt <ejb@ql.org> | 2022-09-09 12:19:09 +0200 |
commit | f1a2d3160a1dbaf735cce597d0f6f40e76f7f223 (patch) | |
tree | 41721144a2d94d962f3de9b48ad58d18bfd838e0 /include | |
parent | 66f1fd2ad9f2a4e3172bd07f6d71bb1321b0dce0 (diff) | |
download | qpdf-f1a2d3160a1dbaf735cce597d0f6f40e76f7f223.tar.zst |
Add JSON v2 support to C API
Diffstat (limited to 'include')
-rw-r--r-- | include/qpdf/qpdf-c.h | 75 |
1 files changed, 71 insertions, 4 deletions
diff --git a/include/qpdf/qpdf-c.h b/include/qpdf/qpdf-c.h index 4b40f068..434c4ede 100644 --- a/include/qpdf/qpdf-c.h +++ b/include/qpdf/qpdf-c.h @@ -257,8 +257,6 @@ extern "C" { QPDF_DLL QPDF_ERROR_CODE qpdf_check_pdf(qpdf_data qpdf); - /* READ FUNCTIONS */ - /* READ PARAMETER FUNCTIONS -- must be called before qpdf_read */ QPDF_DLL @@ -267,6 +265,10 @@ extern "C" { QPDF_DLL void qpdf_set_attempt_recovery(qpdf_data qpdf, QPDF_BOOL value); + /* PROCESS FUNCTIONS */ + + /* This functions process a PDF or JSON input source. */ + /* Calling qpdf_read causes processFile to be called in the C++ * API. Basic parsing is performed, but data from the file is * only read as needed. For files without passwords, pass a null @@ -297,8 +299,40 @@ extern "C" { QPDF_DLL QPDF_ERROR_CODE qpdf_empty_pdf(qpdf_data qpdf); - /* Read functions below must be called after qpdf_read or - * qpdf_read_memory. */ + /* Create a PDF from a JSON file. This calls createFromJSON in the + * C++ API. + */ + QPDF_DLL + QPDF_ERROR_CODE + qpdf_create_from_json_file(qpdf_data qpdf, char const* filename); + + /* Create a PDF from JSON data in a null-terminated string. This + * calls createFromJSON in the C++ API. + */ + QPDF_DLL + QPDF_ERROR_CODE + qpdf_create_from_json_data( + qpdf_data qpdf, char const* buffer, unsigned long long size); + + /* JSON UPDATE FUNCTIONS */ + + /* Update a QPDF object from a JSON file or buffer. These + * functions call updateFromJSON. One of the other processing + * functions has to be called first so that the QPDF object is + * initialized with PDF data. + */ + QPDF_DLL + QPDF_ERROR_CODE + qpdf_update_from_json_file(qpdf_data qpdf, char const* filename); + QPDF_DLL + QPDF_ERROR_CODE + qpdf_update_from_json_data( + qpdf_data qpdf, char const* buffer, unsigned long long size); + + /* READ FUNCTIONS */ + + /* Read functions below must be called after qpdf_read or any of + * the other functions that process a PDF. */ /* * NOTE: Functions that return char* are returning a pointer to an @@ -371,6 +405,39 @@ extern "C" { QPDF_DLL QPDF_BOOL qpdf_allow_modify_all(qpdf_data qpdf); + /* JSON WRITE FUNCTIONS */ + + /* This function serializes the PDF to JSON. This calls writeJSON + * from the C++ API. + * + * - version: the JSON version, currently must be 2 + * - fn: a function that will be called with blocks of JSON data; + * will be called with data, a length, and the value of the + * udata parameter to this function + * - udata: will be passed as the third argument to fn with each + * call; use this for your own tracking or pass a null pointer + * if you don't need it + * - For decode_level, json_stream_data, file_prefix, and + * wanted_objects, see comments in QPDF.hh. For this API, + * wanted_objects should be a null-terminated array of + * null-terminated strings. Pass a null pointer if you want all + * objects. + */ + + /* Function should return 0 on success. */ + typedef int (*qpdf_write_fn_t)(char const* data, size_t len, void* udata); + + QPDF_DLL + QPDF_ERROR_CODE qpdf_write_json( + qpdf_data qpdf, + int version, + qpdf_write_fn_t fn, + void* udata, + enum qpdf_stream_decode_level_e decode_level, + enum qpdf_json_stream_data_e json_stream_data, + char const* file_prefix, + char const* const* wanted_objects); + /* WRITE FUNCTIONS */ /* Set up for writing. No writing is actually performed until the |