-
Notifications
You must be signed in to change notification settings - Fork 0
Debugging pdf.js
As a safety precaution the debugging tools for the extension and the version of pdf.js bundled with firefox will require the user to set a pref in about:config
:
- Extension Version:
[email protected]
setting (booleantrue
) - Mozilla Central(Firefox) Version:
pdfjs.pdfBugEnabled
setting (booleantrue
)
pdf.js has several special url parameters to alter how pdf.js works and 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.
To enable see above.
id: FontInspector
The font inspector allows you to view what fonts are used within page. It also allows you to download the base64 version of the font which can be copied into the online font sanitizer that provides more information about why a font is being rejected (see http://async5.org/ots-95/ots.html). Further, you can download the font and use the base64
command on most unix systems to decode the font and save it as a true type font file. The decoded font file can then be checked with more programs such as FontForge, Microsoft Font Validator, Adobe FDK, or ttx.
id: Stepper
The stepper tool makes it so you can 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 is structured and the order of its operations. To walk through the drawing commands first 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).