2
1
mirror of https://github.com/qpdf/qpdf.git synced 2025-01-07 00:53:56 +00:00

DLL.hh -> DLL.h, move public enumerated types into Constants.h and use them both for C and C++ interfaces

git-svn-id: svn+q:///qpdf/trunk@828 71b93d88-0707-0410-a8cf-f5a4172ac649
This commit is contained in:
Jay Berkenbilt 2009-10-19 20:17:14 +00:00
parent 734ac1e1d2
commit b67a3c15e7
24 changed files with 145 additions and 174 deletions

View File

@ -200,7 +200,7 @@ int main(int argc, char* argv[])
} }
} }
QPDFWriter w(file, fl_tmp.c_str()); QPDFWriter w(file, fl_tmp.c_str());
w.setStreamDataMode(QPDFWriter::s_preserve); w.setStreamDataMode(qpdf_s_preserve);
w.setLinearization(true); w.setLinearization(true);
w.setStaticID(static_id); w.setStaticID(static_id);
w.write(); w.write();

View File

@ -8,7 +8,7 @@
#ifndef __BUFFER_HH__ #ifndef __BUFFER_HH__
#define __BUFFER_HH__ #define __BUFFER_HH__
#include <qpdf/DLL.hh> #include <qpdf/DLL.h>
class DLL_EXPORT Buffer class DLL_EXPORT Buffer
{ {

52
include/qpdf/Constants.h Normal file
View File

@ -0,0 +1,52 @@
#ifndef __QPDFCONSTANTS_H__
#define __QPDFCONSTANTS_H__
/* Keep this file 'C' compatible so it can be used from the C and C++
* interfaces.
*/
/* Error Codes */
enum qpdf_error_code_e
{
qpdf_e_success = 0,
qpdf_e_internal, /* logic/programming error -- indicates bug */
qpdf_e_system, /* I/O error, memory error, etc. */
qpdf_e_unsupported, /* PDF feature not (yet) supported by qpdf */
qpdf_e_password, /* incorrect password for encrypted file */
qpdf_e_damaged_pdf /* syntax errors or other damage in PDF */
};
/* Write Parameters */
enum qpdf_object_stream_e
{
qpdf_o_disable = 0, /* disable object streams */
qpdf_o_preserve, /* preserve object streams */
qpdf_o_generate /* generate object streams */
};
enum qpdf_stream_data_e
{
qpdf_s_uncompress = 0, /* uncompress stream data */
qpdf_s_preserve, /* preserve stream data compression */
qpdf_s_compress /* compress stream data */
};
/* R3 Encryption Parameters */
enum qpdf_r3_print_e
{
qpdf_r3p_full = 0, /* allow all printing */
qpdf_r3p_low, /* allow only low-resolution printing */
qpdf_r3p_none /* allow no printing */
};
enum qpdf_r3_modify_e
{
qpdf_r3m_all = 0, /* allow all modification */
qpdf_r3m_annotate, /* allow comment authoring and form operations */
qpdf_r3m_form, /* allow form field fill-in or signing */
qpdf_r3m_assembly, /* allow only document assembly */
qpdf_r3m_none /* allow no modification */
};
#endif /* __QPDFCONSTANTS_H__ */

View File

@ -7,4 +7,4 @@
# define DLL_EXPORT # define DLL_EXPORT
#endif #endif
#endif // __QPDF_DLL_HH__ #endif /* __QPDF_DLL_HH__ */

View File

@ -30,7 +30,7 @@
#ifndef __PIPELINE_HH__ #ifndef __PIPELINE_HH__
#define __PIPELINE_HH__ #define __PIPELINE_HH__
#include <qpdf/DLL.hh> #include <qpdf/DLL.h>
#include <string> #include <string>
class DLL_EXPORT Pipeline class DLL_EXPORT Pipeline

View File

@ -13,7 +13,7 @@
#include <map> #include <map>
#include <list> #include <list>
#include <qpdf/DLL.hh> #include <qpdf/DLL.h>
#include <qpdf/QPDFXRefEntry.hh> #include <qpdf/QPDFXRefEntry.hh>
#include <qpdf/QPDFObjectHandle.hh> #include <qpdf/QPDFObjectHandle.hh>

View File

@ -8,7 +8,7 @@
#ifndef __QPDFEXC_HH__ #ifndef __QPDFEXC_HH__
#define __QPDFEXC_HH__ #define __QPDFEXC_HH__
#include <qpdf/DLL.hh> #include <qpdf/DLL.h>
#include <stdexcept> #include <stdexcept>
class DLL_EXPORT QPDFExc: public std::runtime_error class DLL_EXPORT QPDFExc: public std::runtime_error

View File

@ -8,7 +8,7 @@
#ifndef __QPDFOBJECT_HH__ #ifndef __QPDFOBJECT_HH__
#define __QPDFOBJECT_HH__ #define __QPDFOBJECT_HH__
#include <qpdf/DLL.hh> #include <qpdf/DLL.h>
#include <string> #include <string>

View File

@ -13,7 +13,7 @@
#include <set> #include <set>
#include <map> #include <map>
#include <qpdf/DLL.hh> #include <qpdf/DLL.h>
#include <qpdf/PointerHolder.hh> #include <qpdf/PointerHolder.hh>
#include <qpdf/Buffer.hh> #include <qpdf/Buffer.hh>

View File

@ -8,7 +8,7 @@
#ifndef __QPDFTOKENIZER_HH__ #ifndef __QPDFTOKENIZER_HH__
#define __QPDFTOKENIZER_HH__ #define __QPDFTOKENIZER_HH__
#include <qpdf/DLL.hh> #include <qpdf/DLL.h>
#include <string> #include <string>
#include <stdio.h> #include <stdio.h>

View File

@ -19,7 +19,8 @@
#include <set> #include <set>
#include <map> #include <map>
#include <qpdf/DLL.hh> #include <qpdf/DLL.h>
#include <qpdf/Constants.h>
#include <qpdf/QPDFXRefEntry.hh> #include <qpdf/QPDFXRefEntry.hh>
@ -51,16 +52,14 @@ class DLL_EXPORT QPDFWriter
// generate a conventional cross-reference table if there are no // generate a conventional cross-reference table if there are no
// object streams and a cross-reference stream if there are object // object streams and a cross-reference stream if there are object
// streams. The default is o_preserve. // streams. The default is o_preserve.
enum object_stream_e { o_disable, o_preserve, o_generate }; void setObjectStreamMode(qpdf_object_stream_e);
void setObjectStreamMode(object_stream_e);
// Set value of stream data mode. In uncompress mode, we attempt // Set value of stream data mode. In uncompress mode, we attempt
// to uncompress any stream that we can. In preserve mode, we // to uncompress any stream that we can. In preserve mode, we
// preserve any filtering applied to streams. In compress mode, // preserve any filtering applied to streams. In compress mode,
// if we can apply all filters and the stream is not already // if we can apply all filters and the stream is not already
// optimally compressed, recompress the stream. // optimally compressed, recompress the stream.
enum stream_data_e { s_uncompress, s_preserve, s_compress }; void setStreamDataMode(qpdf_stream_data_e);
void setStreamDataMode(stream_data_e);
// Set value of content stream normalization. The default is // Set value of content stream normalization. The default is
// "false". If true, we attempt to normalize newlines inside of // "false". If true, we attempt to normalize newlines inside of
@ -137,28 +136,14 @@ class DLL_EXPORT QPDFWriter
char const* user_password, char const* owner_password, char const* user_password, char const* owner_password,
bool allow_print, bool allow_modify, bool allow_print, bool allow_modify,
bool allow_extract, bool allow_annotate); bool allow_extract, bool allow_annotate);
enum r3_print_e
{
r3p_full, // allow all printing
r3p_low, // allow only low-resolution printing
r3p_none // allow no printing
};
enum r3_modify_e
{
r3m_all, // allow all modification
r3m_annotate, // allow comment authoring and form operations
r3m_form, // allow form field fill-in or signing
r3m_assembly, // allow only document assembly
r3m_none // allow no modification
};
void setR3EncryptionParameters( void setR3EncryptionParameters(
char const* user_password, char const* owner_password, char const* user_password, char const* owner_password,
bool allow_accessibility, bool allow_extract, bool allow_accessibility, bool allow_extract,
r3_print_e print, r3_modify_e modify); qpdf_r3_print_e print, qpdf_r3_modify_e modify);
void setR4EncryptionParameters( void setR4EncryptionParameters(
char const* user_password, char const* owner_password, char const* user_password, char const* owner_password,
bool allow_accessibility, bool allow_extract, bool allow_accessibility, bool allow_extract,
r3_print_e print, r3_modify_e modify, qpdf_r3_print_e print, qpdf_r3_modify_e modify,
bool encrypt_metadata, bool use_aes); bool encrypt_metadata, bool use_aes);
// Create linearized output. Disables qdf mode, content // Create linearized output. Disables qdf mode, content
@ -203,7 +188,7 @@ class DLL_EXPORT QPDFWriter
std::set<int>& bits_to_clear, std::set<int>& bits_to_clear,
char const* user_password, char const* owner_password, char const* user_password, char const* owner_password,
bool allow_accessibility, bool allow_extract, bool allow_accessibility, bool allow_extract,
r3_print_e print, r3_modify_e modify); qpdf_r3_print_e print, qpdf_r3_modify_e modify);
void disableIncompatbleEncryption(float v); void disableIncompatbleEncryption(float v);
void setEncryptionParameters( void setEncryptionParameters(
char const* user_password, char const* owner_password, char const* user_password, char const* owner_password,
@ -265,7 +250,7 @@ class DLL_EXPORT QPDFWriter
bool normalize_content_set; bool normalize_content_set;
bool normalize_content; bool normalize_content;
bool stream_data_mode_set; bool stream_data_mode_set;
stream_data_e stream_data_mode; qpdf_stream_data_e stream_data_mode;
bool qdf_mode; bool qdf_mode;
bool static_id; bool static_id;
bool suppress_original_object_ids; bool suppress_original_object_ids;
@ -273,7 +258,7 @@ class DLL_EXPORT QPDFWriter
bool encrypted; bool encrypted;
bool preserve_encryption; bool preserve_encryption;
bool linearized; bool linearized;
object_stream_e object_stream_mode; qpdf_object_stream_e object_stream_mode;
std::string encryption_key; std::string encryption_key;
bool encrypt_metadata; bool encrypt_metadata;
bool encrypt_use_aes; bool encrypt_use_aes;

View File

@ -8,7 +8,7 @@
#ifndef __QPDFXREFENTRY_HH__ #ifndef __QPDFXREFENTRY_HH__
#define __QPDFXREFENTRY_HH__ #define __QPDFXREFENTRY_HH__
#include <qpdf/DLL.hh> #include <qpdf/DLL.h>
class DLL_EXPORT QPDFXRefEntry class DLL_EXPORT QPDFXRefEntry
{ {

View File

@ -8,7 +8,7 @@
#ifndef __QTC_HH__ #ifndef __QTC_HH__
#define __QTC_HH__ #define __QTC_HH__
#include <qpdf/DLL.hh> #include <qpdf/DLL.h>
namespace QTC namespace QTC
{ {

View File

@ -8,7 +8,7 @@
#ifndef __QUTIL_HH__ #ifndef __QUTIL_HH__
#define __QUTIL_HH__ #define __QUTIL_HH__
#include <qpdf/DLL.hh> #include <qpdf/DLL.h>
#include <string> #include <string>
#include <list> #include <list>
#include <stdexcept> #include <stdexcept>

View File

@ -61,7 +61,8 @@
* primarily on differences between the C and C++ API. * primarily on differences between the C and C++ API.
*/ */
#include <qpdf/DLL.hh> #include <qpdf/DLL.h>
#include <qpdf/Constants.h>
#ifdef __cplusplus #ifdef __cplusplus
extern "C" { extern "C" {
@ -199,20 +200,13 @@ extern "C" {
DLL_EXPORT DLL_EXPORT
QPDF_ERROR_CODE qpdf_init_write(qpdf_data qpdf, char const* filename); QPDF_ERROR_CODE qpdf_init_write(qpdf_data qpdf, char const* filename);
# define QPDF_OBJECT_STREAM_DISABLE 0
# define QPDF_OBJECT_STREAM_PRESERVE 1
# define QPDF_OBJECT_STREAM_GENERATE 2
/* For mode, pass one of the QPDF_OBJECT_STREAM constants. */
DLL_EXPORT DLL_EXPORT
void qpdf_set_object_stream_mode(qpdf_data qpdf, int mode); void qpdf_set_object_stream_mode(qpdf_data qpdf,
enum qpdf_object_stream_e mode);
# define QPDF_STREAM_DATA_UNCOMPRESS 0
# define QPDF_STREAM_DATA_PRESERVE 1
# define QPDF_STREAM_DATA_COMPRESS 2
/* For mode, pass one of the QPDF_STREAM_DATA constants. */
DLL_EXPORT DLL_EXPORT
void qpdf_set_stream_data_mode(qpdf_data qpdf, int mode); void qpdf_set_stream_data_mode(qpdf_data qpdf,
enum qpdf_stream_data_e mode);
DLL_EXPORT DLL_EXPORT
void qpdf_set_content_normalization(qpdf_data qpdf, QPDF_BOOL value); void qpdf_set_content_normalization(qpdf_data qpdf, QPDF_BOOL value);
@ -245,30 +239,17 @@ extern "C" {
QPDF_BOOL allow_print, QPDF_BOOL allow_modify, QPDF_BOOL allow_print, QPDF_BOOL allow_modify,
QPDF_BOOL allow_extract, QPDF_BOOL allow_annotate); QPDF_BOOL allow_extract, QPDF_BOOL allow_annotate);
# define QPDF_R3_PRINT_FULL 0
# define QPDF_R3_PRINT_LOW 1
# define QPDF_R3_PRINT_NONE 2
# define QPDF_R3_MODIFY_ALL 0
# define QPDF_R3_MODIFY_ANNOTATE 1
# define QPDF_R3_MODIFY_FORM 2
# define QPDF_R3_MODIFY_ASSEMBLY 3
# define QPDF_R3_MODIFY_NONE 4
/* Value of print should be one of the QPDF_R3_PRINT constants.
* Value of modify should be one of the QPDF_R3_MODIFY constants.
*/
DLL_EXPORT DLL_EXPORT
void qpdf_set_r3_encryption_parameters( void qpdf_set_r3_encryption_parameters(
qpdf_data qpdf, char const* user_password, char const* owner_password, qpdf_data qpdf, char const* user_password, char const* owner_password,
QPDF_BOOL allow_accessibility, QPDF_BOOL allow_extract, QPDF_BOOL allow_accessibility, QPDF_BOOL allow_extract,
int print, int modify); enum qpdf_r3_print_e print, enum qpdf_r3_modify_e modify);
DLL_EXPORT DLL_EXPORT
void qpdf_set_r4_encryption_parameters( void qpdf_set_r4_encryption_parameters(
qpdf_data qpdf, char const* user_password, char const* owner_password, qpdf_data qpdf, char const* user_password, char const* owner_password,
QPDF_BOOL allow_accessibility, QPDF_BOOL allow_extract, QPDF_BOOL allow_accessibility, QPDF_BOOL allow_extract,
int print, int modify, enum qpdf_r3_print_e print, enum qpdf_r3_modify_e modify,
QPDF_BOOL encrypt_metadata, QPDF_BOOL use_aes); QPDF_BOOL encrypt_metadata, QPDF_BOOL use_aes);
DLL_EXPORT DLL_EXPORT

View File

@ -29,7 +29,7 @@ QPDFWriter::QPDFWriter(QPDF& pdf, char const* filename) :
normalize_content_set(false), normalize_content_set(false),
normalize_content(false), normalize_content(false),
stream_data_mode_set(false), stream_data_mode_set(false),
stream_data_mode(s_compress), stream_data_mode(qpdf_s_compress),
qdf_mode(false), qdf_mode(false),
static_id(false), static_id(false),
suppress_original_object_ids(false), suppress_original_object_ids(false),
@ -37,7 +37,7 @@ QPDFWriter::QPDFWriter(QPDF& pdf, char const* filename) :
encrypted(false), encrypted(false),
preserve_encryption(true), preserve_encryption(true),
linearized(false), linearized(false),
object_stream_mode(o_preserve), object_stream_mode(qpdf_o_preserve),
encrypt_metadata(true), encrypt_metadata(true),
encrypt_use_aes(false), encrypt_use_aes(false),
encryption_dict_objid(0), encryption_dict_objid(0),
@ -77,13 +77,13 @@ QPDFWriter::~QPDFWriter()
} }
void void
QPDFWriter::setObjectStreamMode(object_stream_e mode) QPDFWriter::setObjectStreamMode(qpdf_object_stream_e mode)
{ {
this->object_stream_mode = mode; this->object_stream_mode = mode;
} }
void void
QPDFWriter::setStreamDataMode(stream_data_e mode) QPDFWriter::setStreamDataMode(qpdf_stream_data_e mode)
{ {
this->stream_data_mode_set = true; this->stream_data_mode_set = true;
this->stream_data_mode = mode; this->stream_data_mode = mode;
@ -198,7 +198,7 @@ void
QPDFWriter::setR3EncryptionParameters( QPDFWriter::setR3EncryptionParameters(
char const* user_password, char const* owner_password, char const* user_password, char const* owner_password,
bool allow_accessibility, bool allow_extract, bool allow_accessibility, bool allow_extract,
r3_print_e print, r3_modify_e modify) qpdf_r3_print_e print, qpdf_r3_modify_e modify)
{ {
std::set<int> clear; std::set<int> clear;
interpretR3EncryptionParameters( interpretR3EncryptionParameters(
@ -212,7 +212,7 @@ void
QPDFWriter::setR4EncryptionParameters( QPDFWriter::setR4EncryptionParameters(
char const* user_password, char const* owner_password, char const* user_password, char const* owner_password,
bool allow_accessibility, bool allow_extract, bool allow_accessibility, bool allow_extract,
r3_print_e print, r3_modify_e modify, qpdf_r3_print_e print, qpdf_r3_modify_e modify,
bool encrypt_metadata, bool use_aes) bool encrypt_metadata, bool use_aes)
{ {
std::set<int> clear; std::set<int> clear;
@ -230,7 +230,7 @@ QPDFWriter::interpretR3EncryptionParameters(
std::set<int>& clear, std::set<int>& clear,
char const* user_password, char const* owner_password, char const* user_password, char const* owner_password,
bool allow_accessibility, bool allow_extract, bool allow_accessibility, bool allow_extract,
r3_print_e print, r3_modify_e modify) qpdf_r3_print_e print, qpdf_r3_modify_e modify)
{ {
// Acrobat 5 security options: // Acrobat 5 security options:
@ -263,13 +263,13 @@ QPDFWriter::interpretR3EncryptionParameters(
// statements). Each option clears successively more access bits. // statements). Each option clears successively more access bits.
switch (print) switch (print)
{ {
case r3p_none: case qpdf_r3p_none:
clear.insert(3); // any printing clear.insert(3); // any printing
case r3p_low: case qpdf_r3p_low:
clear.insert(12); // high resolution printing clear.insert(12); // high resolution printing
case r3p_full: case qpdf_r3p_full:
break; break;
// no default so gcc warns for missing cases // no default so gcc warns for missing cases
@ -277,19 +277,19 @@ QPDFWriter::interpretR3EncryptionParameters(
switch (modify) switch (modify)
{ {
case r3m_none: case qpdf_r3m_none:
clear.insert(11); // document assembly clear.insert(11); // document assembly
case r3m_assembly: case qpdf_r3m_assembly:
clear.insert(9); // filling in form fields clear.insert(9); // filling in form fields
case r3m_form: case qpdf_r3m_form:
clear.insert(6); // modify annotations, fill in form fields clear.insert(6); // modify annotations, fill in form fields
case r3m_annotate: case qpdf_r3m_annotate:
clear.insert(4); // other modifications clear.insert(4); // other modifications
case r3m_all: case qpdf_r3m_all:
break; break;
// no default so gcc warns for missing cases // no default so gcc warns for missing cases
@ -922,8 +922,8 @@ QPDFWriter::unparseObject(QPDFObjectHandle object, int level,
{ {
is_metadata = true; is_metadata = true;
} }
bool filter = (this->stream_data_mode != s_preserve); bool filter = (this->stream_data_mode != qpdf_s_preserve);
if (this->stream_data_mode == s_compress) if (this->stream_data_mode == qpdf_s_compress)
{ {
// Don't filter if the stream is already compressed with // Don't filter if the stream is already compressed with
// FlateDecode. We don't want to make it worse by getting // FlateDecode. We don't want to make it worse by getting
@ -952,7 +952,7 @@ QPDFWriter::unparseObject(QPDFObjectHandle object, int level,
normalize = true; normalize = true;
filter = true; filter = true;
} }
else if (filter && (this->stream_data_mode == s_compress)) else if (filter && (this->stream_data_mode == qpdf_s_compress))
{ {
compress = true; compress = true;
QTC::TC("qpdf", "QPDFWriter compressing uncompressed stream"); QTC::TC("qpdf", "QPDFWriter compressing uncompressed stream");
@ -1107,7 +1107,8 @@ QPDFWriter::writeObjectStream(QPDFObjectHandle object)
// Set up a stream to write the stream data into a buffer. // Set up a stream to write the stream data into a buffer.
Pipeline* next = pushPipeline(new Pl_Buffer("object stream")); Pipeline* next = pushPipeline(new Pl_Buffer("object stream"));
if (! ((this->stream_data_mode == s_uncompress) || this->qdf_mode)) if (! ((this->stream_data_mode == qpdf_s_uncompress) ||
this->qdf_mode))
{ {
compressed = true; compressed = true;
next = pushPipeline( next = pushPipeline(
@ -1455,7 +1456,7 @@ QPDFWriter::write()
} }
if (! this->stream_data_mode_set) if (! this->stream_data_mode_set)
{ {
this->stream_data_mode = s_uncompress; this->stream_data_mode = qpdf_s_uncompress;
} }
} }
@ -1465,7 +1466,7 @@ QPDFWriter::write()
this->preserve_encryption = false; this->preserve_encryption = false;
} }
else if (this->normalize_content || else if (this->normalize_content ||
(this->stream_data_mode == s_uncompress) || (this->stream_data_mode == qpdf_s_uncompress) ||
this->qdf_mode) this->qdf_mode)
{ {
// Encryption makes looking at contents pretty useless. If // Encryption makes looking at contents pretty useless. If
@ -1485,12 +1486,12 @@ QPDFWriter::write()
if (v < 1.5) if (v < 1.5)
{ {
QTC::TC("qpdf", "QPDFWriter forcing object stream disable"); QTC::TC("qpdf", "QPDFWriter forcing object stream disable");
this->object_stream_mode = o_disable; this->object_stream_mode = qpdf_o_disable;
} }
} }
if (this->qdf_mode || this->normalize_content || if (this->qdf_mode || this->normalize_content ||
(this->stream_data_mode == s_uncompress)) (this->stream_data_mode == qpdf_s_uncompress))
{ {
initializeSpecialStreams(); initializeSpecialStreams();
} }
@ -1506,15 +1507,15 @@ QPDFWriter::write()
switch (this->object_stream_mode) switch (this->object_stream_mode)
{ {
case o_disable: case qpdf_o_disable:
// no action required // no action required
break; break;
case o_preserve: case qpdf_o_preserve:
preserveObjectStreams(); preserveObjectStreams();
break; break;
case o_generate: case qpdf_o_generate:
generateObjectStreams(); generateObjectStreams();
break; break;
@ -1760,7 +1761,7 @@ QPDFWriter::writeXRefStream(int xref_id, int max_id, int max_offset,
Pipeline* p = pushPipeline(new Pl_Buffer("xref stream")); Pipeline* p = pushPipeline(new Pl_Buffer("xref stream"));
bool compressed = false; bool compressed = false;
if (! ((this->stream_data_mode == s_uncompress) || this->qdf_mode)) if (! ((this->stream_data_mode == qpdf_s_uncompress) || this->qdf_mode))
{ {
compressed = true; compressed = true;
p = pushPipeline( p = pushPipeline(

View File

@ -1,4 +1,3 @@
#include <qpdf/DLL.hh>
#include <qpdf/QUtil.hh> #include <qpdf/QUtil.hh>
#include <stdio.h> #include <stdio.h>
#include <errno.h> #include <errno.h>

View File

@ -251,48 +251,16 @@ QPDF_ERROR_CODE qpdf_init_write(qpdf_data qpdf, char const* filename)
return status; return status;
} }
void qpdf_set_object_stream_mode(qpdf_data qpdf, int mode) void qpdf_set_object_stream_mode(qpdf_data qpdf, qpdf_object_stream_e mode)
{ {
QTC::TC("qpdf", "qpdf-c called qpdf_set_object_stream_mode"); QTC::TC("qpdf", "qpdf-c called qpdf_set_object_stream_mode");
QPDFWriter::object_stream_e omode = QPDFWriter::o_preserve; qpdf->qpdf_writer->setObjectStreamMode(mode);
switch (mode)
{
case QPDF_OBJECT_STREAM_DISABLE:
omode = QPDFWriter::o_disable;
break;
case QPDF_OBJECT_STREAM_GENERATE:
omode = QPDFWriter::o_generate;
break;
default:
// already set to o_preserve; treate out of range values as
// the default.
break;
} }
qpdf->qpdf_writer->setObjectStreamMode(omode); void qpdf_set_stream_data_mode(qpdf_data qpdf, qpdf_stream_data_e mode)
}
void qpdf_set_stream_data_mode(qpdf_data qpdf, int mode)
{ {
QTC::TC("qpdf", "qpdf-c called qpdf_set_stream_data_mode"); QTC::TC("qpdf", "qpdf-c called qpdf_set_stream_data_mode");
QPDFWriter::stream_data_e smode = QPDFWriter::s_preserve; qpdf->qpdf_writer->setStreamDataMode(mode);
switch (mode)
{
case QPDF_STREAM_DATA_UNCOMPRESS:
smode = QPDFWriter::s_uncompress;
break;
case QPDF_STREAM_DATA_COMPRESS:
smode = QPDFWriter::s_compress;
break;
default:
// Treat anything else as default
break;
}
qpdf->qpdf_writer->setStreamDataMode(smode);
} }
void qpdf_set_content_normalization(qpdf_data qpdf, QPDF_BOOL value) void qpdf_set_content_normalization(qpdf_data qpdf, QPDF_BOOL value)
@ -346,39 +314,24 @@ void qpdf_set_r2_encryption_parameters(
void qpdf_set_r3_encryption_parameters( void qpdf_set_r3_encryption_parameters(
qpdf_data qpdf, char const* user_password, char const* owner_password, qpdf_data qpdf, char const* user_password, char const* owner_password,
QPDF_BOOL allow_accessibility, QPDF_BOOL allow_extract, QPDF_BOOL allow_accessibility, QPDF_BOOL allow_extract,
int print, int modify) qpdf_r3_print_e print, qpdf_r3_modify_e modify)
{ {
QTC::TC("qpdf", "qpdf-c called qpdf_set_r3_encryption_parameters"); QTC::TC("qpdf", "qpdf-c called qpdf_set_r3_encryption_parameters");
qpdf->qpdf_writer->setR3EncryptionParameters( qpdf->qpdf_writer->setR3EncryptionParameters(
user_password, owner_password, user_password, owner_password,
allow_accessibility, allow_extract, allow_accessibility, allow_extract, print, modify);
((print == QPDF_R3_PRINT_LOW) ? QPDFWriter::r3p_low :
(print == QPDF_R3_PRINT_NONE) ? QPDFWriter::r3p_none :
QPDFWriter::r3p_full),
((modify == QPDF_R3_MODIFY_ANNOTATE) ? QPDFWriter::r3m_annotate :
(modify == QPDF_R3_MODIFY_FORM) ? QPDFWriter::r3m_form :
(modify == QPDF_R3_MODIFY_ASSEMBLY) ? QPDFWriter::r3m_assembly :
(modify == QPDF_R3_MODIFY_NONE) ? QPDFWriter::r3m_none :
QPDFWriter::r3m_all));
} }
void qpdf_set_r4_encryption_parameters( void qpdf_set_r4_encryption_parameters(
qpdf_data qpdf, char const* user_password, char const* owner_password, qpdf_data qpdf, char const* user_password, char const* owner_password,
QPDF_BOOL allow_accessibility, QPDF_BOOL allow_extract, QPDF_BOOL allow_accessibility, QPDF_BOOL allow_extract,
int print, int modify, QPDF_BOOL encrypt_metadata, QPDF_BOOL use_aes) qpdf_r3_print_e print, qpdf_r3_modify_e modify,
QPDF_BOOL encrypt_metadata, QPDF_BOOL use_aes)
{ {
QTC::TC("qpdf", "qpdf-c called qpdf_set_r4_encryption_parameters"); QTC::TC("qpdf", "qpdf-c called qpdf_set_r4_encryption_parameters");
qpdf->qpdf_writer->setR4EncryptionParameters( qpdf->qpdf_writer->setR4EncryptionParameters(
user_password, owner_password, user_password, owner_password,
allow_accessibility, allow_extract, allow_accessibility, allow_extract, print, modify,
((print == QPDF_R3_PRINT_LOW) ? QPDFWriter::r3p_low :
(print == QPDF_R3_PRINT_NONE) ? QPDFWriter::r3p_none :
QPDFWriter::r3p_full),
((modify == QPDF_R3_MODIFY_ANNOTATE) ? QPDFWriter::r3m_annotate :
(modify == QPDF_R3_MODIFY_FORM) ? QPDFWriter::r3m_form :
(modify == QPDF_R3_MODIFY_ASSEMBLY) ? QPDFWriter::r3m_assembly :
(modify == QPDF_R3_MODIFY_NONE) ? QPDFWriter::r3m_none :
QPDFWriter::r3m_all),
encrypt_metadata, use_aes); encrypt_metadata, use_aes);
} }

View File

@ -3,7 +3,7 @@
#ifndef __BITSTREAM_HH__ #ifndef __BITSTREAM_HH__
#define __BITSTREAM_HH__ #define __BITSTREAM_HH__
#include <qpdf/DLL.hh> #include <qpdf/DLL.h>
class DLL_EXPORT BitStream class DLL_EXPORT BitStream
{ {

View File

@ -3,7 +3,7 @@
#ifndef __BITWRITER_HH__ #ifndef __BITWRITER_HH__
#define __BITWRITER_HH__ #define __BITWRITER_HH__
#include <qpdf/DLL.hh> #include <qpdf/DLL.h>
class Pipeline; class Pipeline;

View File

@ -2,7 +2,7 @@
#define __MD5_HH__ #define __MD5_HH__
#include <string> #include <string>
#include <qpdf/DLL.hh> #include <qpdf/DLL.h>
#include <qpdf/qpdf-config.h> #include <qpdf/qpdf-config.h>
#ifdef HAVE_INTTYPES_H #ifdef HAVE_INTTYPES_H
# include <inttypes.h> # include <inttypes.h>

View File

@ -12,7 +12,7 @@
#include <string> #include <string>
#include <stdexcept> #include <stdexcept>
#include <qpdf/DLL.hh> #include <qpdf/DLL.h>
// Note: this class does not encapsulate all features of the PCRE // Note: this class does not encapsulate all features of the PCRE
// package -- only those that I actually need right now are here. // package -- only those that I actually need right now are here.

View File

@ -114,7 +114,7 @@ static void test06(char const* infile,
qpdf_read(qpdf, infile, password); qpdf_read(qpdf, infile, password);
qpdf_init_write(qpdf, outfile); qpdf_init_write(qpdf, outfile);
qpdf_set_static_ID(qpdf, QPDF_TRUE); qpdf_set_static_ID(qpdf, QPDF_TRUE);
qpdf_set_object_stream_mode(qpdf, QPDF_OBJECT_STREAM_GENERATE); qpdf_set_object_stream_mode(qpdf, qpdf_o_generate);
qpdf_write(qpdf); qpdf_write(qpdf);
report_errors(); report_errors();
} }
@ -154,7 +154,7 @@ static void test09(char const* infile,
qpdf_read(qpdf, infile, password); qpdf_read(qpdf, infile, password);
qpdf_init_write(qpdf, outfile); qpdf_init_write(qpdf, outfile);
qpdf_set_static_ID(qpdf, QPDF_TRUE); qpdf_set_static_ID(qpdf, QPDF_TRUE);
qpdf_set_stream_data_mode(qpdf, QPDF_STREAM_DATA_UNCOMPRESS); qpdf_set_stream_data_mode(qpdf, qpdf_s_uncompress);
qpdf_write(qpdf); qpdf_write(qpdf);
report_errors(); report_errors();
} }
@ -193,7 +193,7 @@ static void test12(char const* infile,
qpdf_set_static_ID(qpdf, QPDF_TRUE); qpdf_set_static_ID(qpdf, QPDF_TRUE);
qpdf_set_r3_encryption_parameters( qpdf_set_r3_encryption_parameters(
qpdf, "user2", "owner2", QPDF_TRUE, QPDF_TRUE, qpdf, "user2", "owner2", QPDF_TRUE, QPDF_TRUE,
QPDF_R3_PRINT_LOW, QPDF_R3_MODIFY_ALL); qpdf_r3p_low, qpdf_r3m_all);
qpdf_write(qpdf); qpdf_write(qpdf);
report_errors(); report_errors();
} }
@ -240,7 +240,7 @@ static void test15(char const* infile,
qpdf_set_static_aes_IV(qpdf, QPDF_TRUE); qpdf_set_static_aes_IV(qpdf, QPDF_TRUE);
qpdf_set_r4_encryption_parameters( qpdf_set_r4_encryption_parameters(
qpdf, "user2", "owner2", QPDF_TRUE, QPDF_TRUE, qpdf, "user2", "owner2", QPDF_TRUE, QPDF_TRUE,
QPDF_R3_PRINT_LOW, QPDF_R3_MODIFY_ALL, QPDF_TRUE, QPDF_TRUE); qpdf_r3p_low, qpdf_r3m_all, QPDF_TRUE, QPDF_TRUE);
qpdf_write(qpdf); qpdf_write(qpdf);
report_errors(); report_errors();
} }

View File

@ -233,7 +233,7 @@ parse_encrypt_options(
std::string& user_password, std::string& owner_password, int& keylen, std::string& user_password, std::string& owner_password, int& keylen,
bool& r2_print, bool& r2_modify, bool& r2_extract, bool& r2_annotate, bool& r2_print, bool& r2_modify, bool& r2_extract, bool& r2_annotate,
bool& r3_accessibility, bool& r3_extract, bool& r3_accessibility, bool& r3_extract,
QPDFWriter::r3_print_e& r3_print, QPDFWriter::r3_modify_e& r3_modify, qpdf_r3_print_e& r3_print, qpdf_r3_modify_e& r3_modify,
bool& force_V4, bool& cleartext_metadata, bool& use_aes) bool& force_V4, bool& cleartext_metadata, bool& use_aes)
{ {
if (cur_arg + 3 >= argc) if (cur_arg + 3 >= argc)
@ -310,15 +310,15 @@ parse_encrypt_options(
{ {
if (val == "full") if (val == "full")
{ {
r3_print = QPDFWriter::r3p_full; r3_print = qpdf_r3p_full;
} }
else if (val == "low") else if (val == "low")
{ {
r3_print = QPDFWriter::r3p_low; r3_print = qpdf_r3p_low;
} }
else if (val == "none") else if (val == "none")
{ {
r3_print = QPDFWriter::r3p_none; r3_print = qpdf_r3p_none;
} }
else else
{ {
@ -352,23 +352,23 @@ parse_encrypt_options(
{ {
if (val == "all") if (val == "all")
{ {
r3_modify = QPDFWriter::r3m_all; r3_modify = qpdf_r3m_all;
} }
else if (val == "annotate") else if (val == "annotate")
{ {
r3_modify = QPDFWriter::r3m_annotate; r3_modify = qpdf_r3m_annotate;
} }
else if (val == "form") else if (val == "form")
{ {
r3_modify = QPDFWriter::r3m_form; r3_modify = qpdf_r3m_form;
} }
else if (val == "assembly") else if (val == "assembly")
{ {
r3_modify = QPDFWriter::r3m_assembly; r3_modify = qpdf_r3m_assembly;
} }
else if (val == "none") else if (val == "none")
{ {
r3_modify = QPDFWriter::r3m_none; r3_modify = qpdf_r3m_none;
} }
else else
{ {
@ -587,19 +587,19 @@ int main(int argc, char* argv[])
bool r2_annotate = true; bool r2_annotate = true;
bool r3_accessibility = true; bool r3_accessibility = true;
bool r3_extract = true; bool r3_extract = true;
QPDFWriter::r3_print_e r3_print = QPDFWriter::r3p_full; qpdf_r3_print_e r3_print = qpdf_r3p_full;
QPDFWriter::r3_modify_e r3_modify = QPDFWriter::r3m_all; qpdf_r3_modify_e r3_modify = qpdf_r3m_all;
bool force_V4 = false; bool force_V4 = false;
bool cleartext_metadata = false; bool cleartext_metadata = false;
bool use_aes = false; bool use_aes = false;
bool stream_data_set = false; bool stream_data_set = false;
QPDFWriter::stream_data_e stream_data_mode = QPDFWriter::s_compress; qpdf_stream_data_e stream_data_mode = qpdf_s_compress;
bool normalize_set = false; bool normalize_set = false;
bool normalize = false; bool normalize = false;
bool suppress_recovery = false; bool suppress_recovery = false;
bool object_stream_set = false; bool object_stream_set = false;
QPDFWriter::object_stream_e object_stream_mode = QPDFWriter::o_preserve; qpdf_object_stream_e object_stream_mode = qpdf_o_preserve;
bool ignore_xref_streams = false; bool ignore_xref_streams = false;
bool qdf_mode = false; bool qdf_mode = false;
std::string min_version; std::string min_version;
@ -677,15 +677,15 @@ int main(int argc, char* argv[])
stream_data_set = true; stream_data_set = true;
if (strcmp(parameter, "compress") == 0) if (strcmp(parameter, "compress") == 0)
{ {
stream_data_mode = QPDFWriter::s_compress; stream_data_mode = qpdf_s_compress;
} }
else if (strcmp(parameter, "preserve") == 0) else if (strcmp(parameter, "preserve") == 0)
{ {
stream_data_mode = QPDFWriter::s_preserve; stream_data_mode = qpdf_s_preserve;
} }
else if (strcmp(parameter, "uncompress") == 0) else if (strcmp(parameter, "uncompress") == 0)
{ {
stream_data_mode = QPDFWriter::s_uncompress; stream_data_mode = qpdf_s_uncompress;
} }
else else
{ {
@ -716,15 +716,15 @@ int main(int argc, char* argv[])
object_stream_set = true; object_stream_set = true;
if (strcmp(parameter, "disable") == 0) if (strcmp(parameter, "disable") == 0)
{ {
object_stream_mode = QPDFWriter::o_disable; object_stream_mode = qpdf_o_disable;
} }
else if (strcmp(parameter, "preserve") == 0) else if (strcmp(parameter, "preserve") == 0)
{ {
object_stream_mode = QPDFWriter::o_preserve; object_stream_mode = qpdf_o_preserve;
} }
else if (strcmp(parameter, "generate") == 0) else if (strcmp(parameter, "generate") == 0)
{ {
object_stream_mode = QPDFWriter::o_generate; object_stream_mode = qpdf_o_generate;
} }
else else
{ {