Go to file
2011-10-18 01:28:57 +02:00
examples/helloworld Fix lint warnings. 2011-09-27 21:43:48 +03:00
extensions/firefox Remove useless code since the extension is loaded into a privileged chrome:// scope 2011-10-18 01:28:57 +02:00
test Merge pull request #661 from brendandahl/extgstate 2011-10-14 10:55:44 -07:00
utils Name anonymous functions. 2011-10-04 22:21:40 +03:00
web Remove useless code since the extension is loaded into a privileged chrome:// scope 2011-10-18 01:28:57 +02:00
worker Use data directly in PDFDoc. 2011-09-26 20:58:18 +03:00
.gitignore allow custom rules to be defined in local.mk 2011-07-07 12:51:48 -04:00
charsets.js Fix small lint issues. 2011-10-15 14:20:15 +03:00
cidmaps.js Initial CID0 font encodings 2011-09-28 19:54:40 -05:00
crypto.js Use lowercase in function names. 2011-09-28 22:00:12 +03:00
fonts.js Fix warnings in strict mode 2011-10-17 20:39:29 +02:00
glyphlist.js Fix Mode comment lines. 2011-09-12 20:37:33 +03:00
LICENSE Added myself to the license (yay!) 2011-09-16 23:55:06 +01:00
Makefile 'make web' now also bundles extension (xpi) 2011-10-11 15:22:33 -04:00
metrics.js Add use strict to metrics.js 2011-10-15 14:27:14 +03:00
pdf.js Fix warnings in strict mode 2011-10-17 20:39:29 +02:00
README.md Less repeat. 2011-10-07 11:49:57 -07:00

pdf.js

Overview

pdf.js is an HTML5 technology experiment that explores building a faithful and efficient Portable Document Format (PDF) renderer without native code assistance.

pdf.js is community-driven and supported by Mozilla Labs. Our goal is to create a general-purpose, web standards-based platform for parsing and rendering PDFs, and eventually release a PDF reader extension powered by pdf.js. Integration with Firefox is a possibility if the experiment proves successful.

Getting started

Online demo

For an online demo, visit:

This demo provides an interactive interface for displaying and browsing PDFs using the pdf.js API.

Getting the code

To get a local copy of the current code, clone it using git:

$ git clone git://github.com/andreasgal/pdf.js.git pdfjs
$ cd pdfjs

Next, you need to start a local web server as some browsers don't allow opening PDF files for a file:// url:

$ make server

If everything worked out, you can now serve

You can also view all the test pdf files on the right side serving

Learning

Here are some initial pointers to help contributors get off the ground. Additional resources are available in a separate section below.

Introductory video

Check out the presentation by our contributor Julian Viereck on the inner workings of PDF and pdf.js:

Hello world

For a "hello world" example, take a look at:

This example illustrates the bare minimum ingredients for integrating pdf.js in a custom project.

Contributing

pdf.js is a community-driven project, so contributors are always welcome. Simply fork our repo and contribute away. A great place to start is our open issues. For better consistency and long-term stability, please do look around the code and try to follow our conventions. More information about the contributor process can be found on the contributor wiki page.

If you don't want to hack on the project or have little spare time, you still can help! Just open PDFs in the online demo and report any breakage in rendering.

Our Github contributors so far:

You can add your name to it! :)

Running the tests

pdf.js comes with browser-level regression tests that allow one to probe whether it's able to successfully parse PDFs, as well as compare its output against reference images, pixel-by-pixel.

To run the tests, first configure the browser manifest file at:

test/resources/browser_manifests/browser_manifest.json

Sample manifests for different platforms are provided in that directory.

To run all the bundled tests, type:

$ make test

and cross your fingers. Different types of tests are available, see the test manifest file at:

test/test_manifest.json

The test type eq tests whether the output images are identical to reference images. The test type load simply tests whether the file loads without raising any errors.

Running tests through our bot

If you are a reviewer, you can use our remote bot to issue comprehensive tests against reference images before merging pull requests.

See the bot repo for details:

Additional resources

Our demo site is here:

You can read more about pdf.js here:

Talk to us on IRC:

  • #pdfjs on irc.mozilla.org

Join our mailing list:

Subscribe either using lists.mozilla.org or Google Groups:

Follow us on twitter: @pdfjs

A really basic overview of PDF is described here:

A more detailed file example:

The PDF specification itself is an ISO and not freely available. However, there is a "PDF Reference" from Adobe:

Recommended chapters to read: "2. Overview", "3.4 File Structure", "4.1 Graphics Objects" that lists the PDF commands.