2
1
mirror of https://github.com/qpdf/qpdf.git synced 2024-12-31 14:01:59 +00:00
Go to file
2017-08-02 21:08:43 -04:00
contrib Add page rotation example in contrib 2017-07-30 08:55:15 -04:00
doc update release date to actual date 2008-04-29 12:55:25 +00:00
examples Fix command-line checking in pdf-split-pages example 2017-07-30 08:47:09 -04:00
include/qpdf Allow reading command-line args from files (fixes #16) 2017-07-29 22:23:21 -04:00
libqpdf Include missing header in QPDFTokenizer.cc (fixes #125) 2017-07-30 08:47:05 -04:00
libtests Allow reading command-line args from files (fixes #16) 2017-07-29 22:23:21 -04:00
m4 Security: use a secure random number generator 2013-10-18 10:45:12 -04:00
make Updates for newer Windows toolchain 2017-07-26 06:24:07 -04:00
manual Fix doc typo 2017-07-30 20:28:37 -04:00
qpdf Fix off-by-one error in --pages argument parsing (fixes #129) 2017-08-02 21:08:43 -04:00
qtest From qtest: add RM_WS_ONLY_LINES option 2016-01-24 11:58:33 -05:00
zlib-flate ABI change: fix use of off_t, size_t, and integer types 2012-06-20 15:20:26 -04:00
.gitignore Ignore some files created by MSVC 2014-06-07 17:06:13 -04:00
Artistic-2.0 update release date to actual date 2008-04-29 12:55:25 +00:00
autoconf.mk.in Use -Wold-style-cast for C++ if supported 2013-03-04 16:45:15 -05:00
autogen.sh create autogen.sh for convenience 2010-03-27 13:17:17 +00:00
ChangeLog Fix off-by-one error in --pages argument parsing (fixes #129) 2017-08-02 21:08:43 -04:00
config-mingw32 Updates for newer Windows toolchain 2017-07-26 06:24:07 -04:00
config-mingw64 Updates for newer Windows toolchain 2017-07-26 06:24:07 -04:00
config-msvc Updates for newer Windows toolchain 2017-07-26 06:24:07 -04:00
config.guess Update autoconf and libtool files 2012-06-20 08:50:33 -04:00
config.sub Update autoconf and libtool files 2012-06-20 08:50:33 -04:00
configure.ac autoconf: find gnu make as gmake or make (fixes #75) 2017-07-29 12:19:04 -04:00
copy_dlls Updates for newer Windows toolchain 2017-07-26 06:24:07 -04:00
INSTALL update release date to actual date 2008-04-29 12:55:25 +00:00
install-sh Update autoconf and libtool files 2012-06-20 08:50:33 -04:00
ispell-words Fix spelling errors 2015-10-31 18:56:43 -04:00
libqpdf.map Update shared library major version to 10 2012-12-31 10:32:32 -05:00
libqpdf.pc.in Add Requires.private to libqpdf.pc for static linking 2012-11-20 13:57:37 -05:00
ltmain.sh Update autoconf and libtool files 2012-06-20 08:50:33 -04:00
make_dist Linearize manual 2015-10-31 19:10:19 -04:00
make_windows_releases Updates for newer Windows toolchain 2017-07-26 06:24:07 -04:00
make_windows_releases-finish Adjust Windows built to support 32-bit and 64-bit builds 2012-06-21 21:22:35 -04:00
make_windows_releases-msvc Updates for newer Windows toolchain 2017-07-26 06:24:07 -04:00
Makefile Add autofiles.zip make target 2013-01-24 11:35:21 -05:00
mkinstalldirs update libtool and automake pieces 2009-09-26 15:42:39 +00:00
README Add page rotation example in contrib 2017-07-30 08:55:15 -04:00
README-what-to-download.txt Add notes for running more tests on Windows 2016-01-24 11:52:09 -05:00
README-windows-install.txt new 2009-10-23 16:58:52 +00:00
README-windows.txt Updates for newer Windows toolchain 2017-07-26 06:24:07 -04:00
README.hardening Security: replace operator[] with at 2013-10-18 10:45:14 -04:00
README.maintainer Bump library soname 2015-11-10 12:42:37 -05:00
TODO Update TODO 2017-07-29 12:19:04 -04:00

This is the QPDF package.  Information about it can be found at
http://qpdf.sourceforge.net.  The source code repository is hosted
at github: https://github.com/qpdf/qpdf.

QPDF is copyright (c) 2005-2015 Jay Berkenbilt

This software may be distributed under the terms of version 2 of the
Artistic License which may be found in the source distribution as
"Artistic-2.0".  It is provided "as is" without express or implied
warranty.


Prerequisites
=============

QPDF depends on external libraries "zlib" and "pcre".  These are part
of virtually all Linux distributions and are readily available;
download information appears in the documentation.  For Windows, you
can download pre-built binary versions of those libraries for some
compilers; see README-windows.txt for additional details.

QPDF requires a C++ compiler that works with STL.  Your compiler must
also support "long long".  Almost all modern compilers do.  If you are
trying to port qpdf to a compiler that doesn't support long long, you
could change all occurrences of "long long" to "long" in the source
code, noting that this would break binary compatibility with other
builds of qpdf.  Doing so would certainly prevent qpdf from working
with files larger than 2 GB, but remaining functionality would most
likely work fine.  If you built qpdf this way and it passed its test
suite with large file support disabled, you could be confident that
you had an otherwise working qpdf.


Licensing terms of embedded software
====================================

QPDF makes use of zlib and pcre for its functionality.  These packages
can be downloaded separately from their own download locations, or
they can be downloaded in the external-libs area of the qpdf download
site.

The Rijndael encryption implementation used as the basis for AES
encryption and decryption support comes from Philip J. Erdelsky's
public domain implementation.  The files libqpdf/rijndael.cc and
libqpdf/qpdf/rijndael.h remain in the public domain.  They were
obtained from

  http://www.efgh.com/software/rijndael.htm
  http://www.efgh.com/software/rijndael.txt

The embedded sha2 code comes from sphlib 3.0

  http://www.saphir2.com/sphlib/

That code has the following license:

  Copyright (c) 2007-2011  Projet RNRT SAPHIR

  Permission is hereby granted, free of charge, to any person obtaining
  a copy of this software and associated documentation files (the
  "Software"), to deal in the Software without restriction, including
  without limitation the rights to use, copy, modify, merge, publish,
  distribute, sublicense, and/or sell copies of the Software, and to
  permit persons to whom the Software is furnished to do so, subject to
  the following conditions:

  The above copyright notice and this permission notice shall be included
  in all copies or substantial portions of the Software.

  THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
  EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
  MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
  IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY
  CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
  TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
  SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.


Building from a pristine checkout
=================================

When building qpdf from a pristine checkout from version control,
documentation and automatically generated files are not present.
Building on Windows from a pristine checkout is not guaranteed to work
because of issues running autoconf; see README-windows.txt for how to
handle this.  For UNIX and UNIX-like systems, you must have some
addditional tools installed to build from the source repository.  To
do this, you should run

./autogen.sh
./configure --enable-doc-maintenance
make
make install

If you don't have Apache fop and the docbook stylesheets installed,
you won't be able to build documentation.  You can omit
--enable-doc-maintenance and produce working qpdf software that passes
its test suite, but make install will fail because the documentation
files won't exist.  Depending on your purposes, you can either work
around this or grab the docs from a source distribution.


Building from source distribution on UNIX/Linux
===============================================

For UNIX and UNIX-like systems, you can usually get by with just

./configure
make
make install

Packagers may set DESTDIR, in which case make install will install
inside of DESTDIR, as is customary with many packages.  For more
detailed general information, see the "INSTALL" file in this
directory.  If you are already accustomed to building and installing
software that uses autoconf, there's nothing new for you in the
INSTALL file.


Building on Windows
===================

QPDF is known to build and pass its test suite with mingw (latest
version tested: gcc 4.6.2), mingw64 (latest version tested: 4.7.0) and
Microsoft Visual C++ 2010, both 32-bit and 64-bit versions.  MSYS plus
ActiveState Perl is required to build as well in order to get make
and other related tools.  See README-windows.txt for details on how to
build under Windows, see README-windows.txt.


Additional Notes on Build
=========================

QPDF's build system, inspired by abuild (http://www.abuild.org), can
optionally use its own built-in rules rather than using libtool and
obeying the compiler specified with configure.  This can be enabled by
passing --with-buildrules=buildrules where buildrules corresponds to
one of the .mk files (other than rules.mk) in the make directory.
This should never be necessary on a UNIX system, but may be necessary
on a Windows system.  See README-windows.txt for details.  There is a
gcc-linux.mk file enable "gcc-linux" build rules, but it is intended
to help test the build system; Linux users should build with the
"libtools" rules, which are enabled by default.

The QPDF package provides some executables and a software library.  A
user's manual can be found in the "doc" directory.  The docbook
sources to the user's manual can be found in the "manual" directory.

The software library is just libqpdf, and all the header files are in
the qpdf subdirectory.  If you link statically with -lqpdf, then you
will also need to link with -lpcre and -lz.  The shared qpdf library
is linked with -lpcre and -lz, and none of qpdf's public header files
directly include files from pcre or libz, so in many cases, qpdf's
development files are self contained.

To learn about using the library, please read comments in the header
files in include/qpdf, especially QPDF.hh, QPDFObjectHandle.hh, and
QPDFWriter.hh.  You can also study the code of qpdf/qpdf.cc, which
exercises most of the public interface.  There are additional example
programs in the examples directory.  Reading all the source files in
the qpdf directory (including the qpdf command-line tool and some test
drivers) along with the code in the examples directory will give you a
complete picture of every aspect of the public interface. You may also
check programs in the contrib directory. These are not part of QPDF
but have been contributed by other developers.


Additional Notes on Test Suite
==============================

By default, slow tests are disabled.  Slow tests include image
comparison tests and large file tests.  Image comparison tests can be
enabled by passing --enable-test-compare-images to ./configure.  This
was on by default in qpdf versions prior to 3.0, but is now off by
default.  Large file tests can be enabled by passing
--with-large-file-test-path=path to ./configure or by setting the
QPDF_LARGE_FILE_TEST_PATH environment variable.  Run ./configure
--help for additional options.  The test suite provides nearly full
coverage even without these tests.  Unless you are making deep changes
to the library that would impact the contents of the generated PDF
files or testing this on a new platform for the first time, there is
no real reason to run these tests.  If you're just running the test
suite to make sure that qpdf works for your build, the default tests
are adequate.  The configure rules for these tests do nothing other
than setting variables in autoconf.mk, so you can feel free to turn
these on and off directly in autoconf.mk rather than rerunning
configure.

If you are packaging qpdf for a distribution and preparing a build
that is run by an autobuilder, you may want to add the
--enable-show-failed-test-output to configure options.  This way, if
the test suite fails, test failure detail will be included in the
build output.  Otherwise, you will have to have access to the
qtest.log file from the build to view test failures.  The debian
packages for qpdf enable this option, for example.


Random Number Generation
========================

By default, when the qpdf detects either the Windows cryptography API
or the existence of /dev/urandom, /dev/arandom, or /dev/random, it
uses them to generate cryptography secure random numbers.  If none of
these conditions are true, the build will fail with an error.  This
behavior can be modified in several ways:

 * If you configure with --disable-os-secure-random or define
   SKIP_OS_SECURE_RANDOM, qpdf will not attempt to use Windows
   cryptography or the random device.  You must either supply your own
   random data provider or allow use of insecure random numbers.

 * If you configure qpdf with the --enable-insecure-random option or
   define USE_INSECURE_RANDOM, qpdf will try insecure random numbers
   if OS-provided secure random numbers are disabled.  This is not a
   fallback.  In order for insecure random numbers to be used, you
   must also disable OS secure random numbers since, otherwise,
   failure to find OS secure random numbers is a compile error.  The
   insecure random number source is stdlib's random() or rand() calls.
   These random numbers are not cryptography secure, but the qpdf
   library is fully functional using them.  Using non-secure random
   numbers means that it's easier in some cases to guess encryption
   keys.  If you're not generating encrypted files, there's no
   advantage to using secure random numbers.

 * In all cases, you may supply your own random data provider.  To do
   this, derive a class from qpdf/RandomDataProvider (since 5.1.0) and
   call QUtil::setRandomDataProvider before you create any QPDF
   objects.  If you supply your own random data provider, it will
   always be used even if support for one of the other random data
   providers is compiled in.  If you wish to avoid any possibility of
   your build of qpdf from using anything but a user-supplied random
   data provider, you can define SKIP_OS_SECURE_RANDOM and not
   USE_INSECURE_RANDOM.  In this case, qpdf will throw a runtime error
   if any attempt is made to generate random numbers and no random
   data provider has been supplied.

If you are building qpdf on a platform that qpdf doesn't know how to
generate secure random numbers on, a patch would be welcome.