blob: 4e6b16c0da63aac03bbadf0af6c07f530f780d66 [file] [log] [blame] [view]
# Building PDFium
## Prerequisites
Get the chromium depot tools via the instructions at
http://www.chromium.org/developers/how-tos/install-depot-tools (this provides
the gclient utilty needed below).
Also install Python, Subversion, and Git and make sure they're in your path.
Optionally, you may want to install the [Ninja](http://martine.github.io/ninja/)
build system (recommended) rather than using your platform-specific build
system.
## Get the code
```
mkdir pdfium
cd pdfium
gclient config --name . --unmanaged https://pdfium.googlesource.com/pdfium.git
gclient sync
```
## Generate the build files
Now we use the GYP library to generate the build files.
At this point, you have two options. The first option is to use the [Ninja]
(http://martine.github.io/ninja/) build system. This is the default as of
mid-September, 2015. Previously, the second option was the default. Most PDFium
developers use Ninja, as does our [continuous build system]
(http://build.chromium.org/p/client.pdfium/).
On Windows: `build\gyp_pdfium
` For all other platforms: `build/gyp_pdfium
`
The second option is to generate platform-specific build files, i.e. Makefiles
on Linux, sln files on Windows, and xcodeproj files on Mac. To do so, set the
GYP\_GENERATORS environment variable appropriately (e.g. "make", "msvs", or
"xcode") before running the above command.
## Building the code
If you used Ninja, you can build the sample program by: `ninja -C out/Debug
pdfium_test
` You can build the entire product (which includes a few unit tests) by: `ninja
-C out/Debug
`
If you're not using Ninja, then building is platform-specific.
On Linux: `make pdfium_test
`
On Mac, open build/all.xcodeproj
On Windows, open build\all.sln
## Running the sample program
The pdfium\_test program supports reading, parsing, and rasterizing the pages of
a .pdf file to .ppm output image files (windows supports two other formats, and
.png support is available for all platforms in an alternate branch (see branches
section below)). For example: `out/Debug/pdfium_test --ppm path/to/myfile.pdf
`
## Waterfall
The current health of the source tree can be found at
http://build.chromium.org/p/client.pdfium/console
## Branches
There is a branch for a forthcoming feature called XFA that you can get by
following the steps above, then: `git checkout origin/xfa build/gyp_pdfium ninja
-C out/Debug
`
The XFA version of the sample pdfium\_test program supports rasterizing to .png
format files. For example: `out/Debug/pdfium_test --png path/to/myfile.pdf
`