From: Andreas Gal Date: Fri, 17 Jun 2011 23:34:29 +0000 (-0700) Subject: even more error checking for font translation X-Git-Url: https://git.parisson.com/?a=commitdiff_plain;h=a4e1fba9eca17ff8ed03ea87bc53c4c990ac1cbe;p=pdf.js.git even more error checking for font translation --- diff --git a/pdf.js b/pdf.js index d656db8..56ab890 100644 --- a/pdf.js +++ b/pdf.js @@ -1931,12 +1931,12 @@ var CanvasGraphics = (function() { } else if (IsName(encoding)) { var encoding = Encodings[encoding.name]; if (!encoding) - error("Unknown encoding"); + error("Unknown font encoding"); var widths = xref.fetchIfRef(fontDict.get("Widths")); var firstChar = xref.fetchIfRef(fontDict.get("FirstChar")); assertWellFormed(IsArray(widths) && IsInteger(firstChar), - "invalid Widths or FirstChar"); + "invalid font Widths or FirstChar"); var charset = []; for (var j = 0; j < widths.length; j++) { if (widths[j]) @@ -1945,11 +1945,16 @@ var CanvasGraphics = (function() { } } + var subType = fontDict.get("Subtype"); + var bbox = descriptor.get("FontBBox"); + assertWellFormed(IsName(subType) && IsArray(bbox), + "invalid font Subtype or FontBBox"); + var properties = { - type: fontDict.get("Subtype").name, + type: subType.name, encoding: encodingMap, charset: charset, - bbox: descriptor.get("FontBBox") + bbox: bbox }; return {