UNPKG

pdf-lib

Version:

Create and modify PDF files with JavaScript

70 lines (65 loc) 4.49 kB
import { toCharCode } from 'src/utils/strings'; // Mapping from PDFDocEncoding to Unicode code point const pdfDocEncodingToUnicode = new Uint16Array(256); // Initialize the code points which are the same for (let idx = 0; idx < 256; idx++) { pdfDocEncodingToUnicode[idx] = idx; } // Set differences (see "Table D.2 – PDFDocEncoding Character Set" of the PDF spec) pdfDocEncodingToUnicode[0x16] = toCharCode('\u0017'); // SYNCRONOUS IDLE pdfDocEncodingToUnicode[0x18] = toCharCode('\u02D8'); // BREVE pdfDocEncodingToUnicode[0x19] = toCharCode('\u02C7'); // CARON pdfDocEncodingToUnicode[0x1a] = toCharCode('\u02C6'); // MODIFIER LETTER CIRCUMFLEX ACCENT pdfDocEncodingToUnicode[0x1b] = toCharCode('\u02D9'); // DOT ABOVE pdfDocEncodingToUnicode[0x1c] = toCharCode('\u02DD'); // DOUBLE ACUTE ACCENT pdfDocEncodingToUnicode[0x1d] = toCharCode('\u02DB'); // OGONEK pdfDocEncodingToUnicode[0x1e] = toCharCode('\u02DA'); // RING ABOVE pdfDocEncodingToUnicode[0x1f] = toCharCode('\u02DC'); // SMALL TILDE pdfDocEncodingToUnicode[0x7f] = toCharCode('\uFFFD'); // REPLACEMENT CHARACTER (box with questionmark) pdfDocEncodingToUnicode[0x80] = toCharCode('\u2022'); // BULLET pdfDocEncodingToUnicode[0x81] = toCharCode('\u2020'); // DAGGER pdfDocEncodingToUnicode[0x82] = toCharCode('\u2021'); // DOUBLE DAGGER pdfDocEncodingToUnicode[0x83] = toCharCode('\u2026'); // HORIZONTAL ELLIPSIS pdfDocEncodingToUnicode[0x84] = toCharCode('\u2014'); // EM DASH pdfDocEncodingToUnicode[0x85] = toCharCode('\u2013'); // EN DASH pdfDocEncodingToUnicode[0x86] = toCharCode('\u0192'); // LATIN SMALL LETTER SCRIPT F pdfDocEncodingToUnicode[0x87] = toCharCode('\u2044'); // FRACTION SLASH (solidus) pdfDocEncodingToUnicode[0x88] = toCharCode('\u2039'); // SINGLE LEFT-POINTING ANGLE QUOTATION MARK pdfDocEncodingToUnicode[0x89] = toCharCode('\u203A'); // SINGLE RIGHT-POINTING ANGLE QUOTATION MARK pdfDocEncodingToUnicode[0x8a] = toCharCode('\u2212'); // MINUS SIGN pdfDocEncodingToUnicode[0x8b] = toCharCode('\u2030'); // PER MILLE SIGN pdfDocEncodingToUnicode[0x8c] = toCharCode('\u201E'); // DOUBLE LOW-9 QUOTATION MARK (quotedblbase) pdfDocEncodingToUnicode[0x8d] = toCharCode('\u201C'); // LEFT DOUBLE QUOTATION MARK (quotedblleft) pdfDocEncodingToUnicode[0x8e] = toCharCode('\u201D'); // RIGHT DOUBLE QUOTATION MARK (quotedblright) pdfDocEncodingToUnicode[0x8f] = toCharCode('\u2018'); // LEFT SINGLE QUOTATION MARK (quoteleft) pdfDocEncodingToUnicode[0x90] = toCharCode('\u2019'); // RIGHT SINGLE QUOTATION MARK (quoteright) pdfDocEncodingToUnicode[0x91] = toCharCode('\u201A'); // SINGLE LOW-9 QUOTATION MARK (quotesinglbase) pdfDocEncodingToUnicode[0x92] = toCharCode('\u2122'); // TRADE MARK SIGN pdfDocEncodingToUnicode[0x93] = toCharCode('\uFB01'); // LATIN SMALL LIGATURE FI pdfDocEncodingToUnicode[0x94] = toCharCode('\uFB02'); // LATIN SMALL LIGATURE FL pdfDocEncodingToUnicode[0x95] = toCharCode('\u0141'); // LATIN CAPITAL LETTER L WITH STROKE pdfDocEncodingToUnicode[0x96] = toCharCode('\u0152'); // LATIN CAPITAL LIGATURE OE pdfDocEncodingToUnicode[0x97] = toCharCode('\u0160'); // LATIN CAPITAL LETTER S WITH CARON pdfDocEncodingToUnicode[0x98] = toCharCode('\u0178'); // LATIN CAPITAL LETTER Y WITH DIAERESIS pdfDocEncodingToUnicode[0x99] = toCharCode('\u017D'); // LATIN CAPITAL LETTER Z WITH CARON pdfDocEncodingToUnicode[0x9a] = toCharCode('\u0131'); // LATIN SMALL LETTER DOTLESS I pdfDocEncodingToUnicode[0x9b] = toCharCode('\u0142'); // LATIN SMALL LETTER L WITH STROKE pdfDocEncodingToUnicode[0x9c] = toCharCode('\u0153'); // LATIN SMALL LIGATURE OE pdfDocEncodingToUnicode[0x9d] = toCharCode('\u0161'); // LATIN SMALL LETTER S WITH CARON pdfDocEncodingToUnicode[0x9e] = toCharCode('\u017E'); // LATIN SMALL LETTER Z WITH CARON pdfDocEncodingToUnicode[0x9f] = toCharCode('\uFFFD'); // REPLACEMENT CHARACTER (box with questionmark) pdfDocEncodingToUnicode[0xa0] = toCharCode('\u20AC'); // EURO SIGN pdfDocEncodingToUnicode[0xad] = toCharCode('\uFFFD'); // REPLACEMENT CHARACTER (box with questionmark) /** * Decode a byte array into a string using PDFDocEncoding. * * @param bytes a byte array (decimal representation) containing a string * encoded with PDFDocEncoding. */ export const pdfDocEncodingDecode = (bytes: Uint8Array): string => { const codePoints = new Array(bytes.length); for (let idx = 0, len = bytes.length; idx < len; idx++) { codePoints[idx] = pdfDocEncodingToUnicode[bytes[idx]]; } return String.fromCodePoint(...codePoints); };