Debugging PDF.js - PeerJ/pdf.js GitHub Wiki
As a safety precaution the debugging tools/parameters are disabled, and user shall enabled them for the generic viewer, the extension and the version of PDF.js bundled with Firefox.
- Extension version: set/create a
[email protected]
setting as a booleantrue
in 'about:config' - Mozilla Central (Firefox) version: set/create a
pdfjs.pdfBugEnabled
setting as a booleantrue
in 'about:config' - Generic viewer: execute
Preferences.set('pdfBugEnabled', true);
in the JavaScript console
The debugging tools/parameters are always enabled for non-production code.
PDF.js has several special URL parameters to alter how PDF.js works and to enable debugging tools. All of these parameters go into the hash section of the URL (after the # symbol) and follow a query string syntax (e.g. #param1=value1¶m2=value2). Note: since all of these parameters are in the hash section, you have to refresh the page after adding them.
-
pdfBug=all
- Enables all the debugging tools. You can optionally enable specific tools by specifying them by their ID, e.g. pdfBug=FontInspector or pdfBug=Stepper,FontInspector. More about PDFBug below. -
disableWorker=true
- Disables the worker which makes it easier to use debugging tools like Firebug where workers aren't supported yet. -
textLayer=[off|visible|shadow|hover]
- Disables or reveals the text layer that is used for text selection. -
disableFontFace=true
- Disables standard@font-face
font loading and uses the internal font renderer instead. -
disableRange=true
- Disables HTTP range requests when fetching the document. -
disableStream=true
- Disables streaming when fetching the document. -
disableAutoFetch=true
- Disables auto fetching of the document; only gets necessary data to display the current view. Note: streaming also needs to be disabled for this to have any effect. -
useOnlyCssZoom=true
- Disables re-rendering of pages and uses CSS zooming instead. -
verbosity=[0|1|5]
- Specifies the verbosity level of console messages. 0 = only errors, 1 = warnings and errors, 5 = warnings, errors and information messages. -
locale=[en-US|...]
- Specifies which language to use in the viewer UI. For a list of the available locales, see https://github.com/mozilla/pdf.js/tree/master/l10n.
See the instructions above on how to enable these tools.
id: FontInspector
The font inspector allows you to view what fonts are used within page. It also allows you to download the font using Save Link As...
and naming it with a .otf
extension. See the section below on debugging fonts.
id: Stepper
The stepper tool makes it easy for you to step through the drawing commands one at a time and hopefully find where a possible issue is coming from. It is also useful for learning how a PDF document is structured and the order of its operations. To walk through the drawing commands you must add a break point, refresh the page and then use the keys s
to step one command at a time or c
to continue until the next breakpoint (line that is checked).
Inspect the internal object structure and view raw values of a PDF document using http://brendandahl.github.io/pdf.js.utils/browser.
To get a problematic font out of a PDF document, download it first using the font inspector mentioned above.
If the font is failing the open type sanitizer (OTS), Firefox should show a message in the console about the rejected font. Take the base64 version of the font and paste it into the online font sanitizer that provides more information about why the font is being rejected (see http://async5.org/ots-95/ots.html). You can then look the OTS source code linked there to find further information.
If the font isn't failing the sanitizer or the sanitizer error doesn't lead you to the font issue, it is often helpful to use other font tools to try and find the source of the problem.
TTX is probably the most useful tool for debugging fonts. It provides a way to convert fonts to XML and then back to the open type format from the XML. A helpful test is to first convert the font to XML, then back to OTF and then test if the font works using a test HTML page.
% ttx font.otf && ttx font.ttx
If the font works after running through ttx
you can then do a binary diff of the two font files to try and track down the problematic portion. If the font still isn't working after conversion, you can then start removing parts of the XML file and converting it back to OTF to see if which section may be causing issues.
The Adobe Font Development Kit includes the above ttx
program and several other programs such as tx
and sfntedit
. Running the font through tx
can provide warnings and useful information. tx
can be used to do a round-trip conversion to look for problems in a similar fashion as ttx
. For example converting a CID font:
% tx -t1 font.otf font.cid
% tx -cff font.cid font.cff
% sfntedit -a CFF=font.cff font.otf
% sfntedit -f font.otf
Other Font Tools