diff options
author | Ken Sharp <ken.sharp@artifex.com> | 2009-07-28 16:20:51 +0000 |
---|---|---|
committer | Ken Sharp <ken.sharp@artifex.com> | 2009-07-28 16:20:51 +0000 |
commit | 346797ab8b52ee71f2f5417747d7a0f8dbb10e96 (patch) | |
tree | 04cedf2955a7cb851fa7e1b3a6365f3036d73346 | |
parent | d44f38bedfd50a7210ef6a50fb955b3a8a94d07c (diff) | |
download | ghostpdl-346797ab8b52ee71f2f5417747d7a0f8dbb10e96.tar.gz |
Fix (pdfwrite): Excessive redefinitions of CIDFonts causing memory exhaustion
Details:
bug #690642: "conversion to PDF aborts after 800 pages"
When instantiating a CIDFont with TrueType outlines, the TrueType interpretation code
tries to name the font using the name table from the TrueType font. If there is no name
table (as is the case for CIDFonts with TT outlines) it instead uses the XUID as the
name.
The XUID is incremented on every use, this means that each time the font is instantiated
(up to once per page when the job is PDF) we create a new CIDFont with a new name.
pdfwrite is unable to determine that these are all in fact the same original font, and
creates many fonts in the output file, eventually leading to memory exhaustion.
This change creates a new key in the current dictionary '/PDFCIDFontName', while
processing a CIDFont with TrueType outlines for a PDF file, which is the same as the
CIDFont BaseFont name. Since PDF can only have one descendant font per CIDFont this
should not cause name collisions. To avoid interference with PostScript the key is
removed from the current dictionary after use.
In the TrueType interpreter, if we are handling a CIDRFont then after loading the TT
tables we check to see if /PDFCIDFontName is defined. If it is we use it to replace the
/FontName and /CIFontName values. This means we only ever create the font with a single
name, which avoids the confusion with pdfwrite.
With this change pdfwrite only emits a single font and, usefully, it has the same name
as the font in the original PDF file.
Expected Differences
None
git-svn-id: http://svn.ghostscript.com/ghostscript/trunk@9897 a1074d23-0009-0410-80fe-cf8c14f379e6
-rw-r--r-- | gs/Resource/Init/gs_ttf.ps | 9 | ||||
-rw-r--r-- | gs/Resource/Init/pdf_font.ps | 3 |
2 files changed, 12 insertions, 0 deletions
diff --git a/gs/Resource/Init/gs_ttf.ps b/gs/Resource/Init/gs_ttf.ps index da0dab6b6..0e9a2c87b 100644 --- a/gs/Resource/Init/gs_ttf.ps +++ b/gs/Resource/Init/gs_ttf.ps @@ -1605,6 +1605,15 @@ currentdict /postalias undef % CIDFontType2 fonts don't have a cmap: they are indexed by CID. mark .ttkeys + /PDFCIDFontName where { % Only set if called by the PDF interpreter. + pop % Remove the dictionary where it is defined. + /fontname PDFCIDFontName def % Use the substitute name, not the name from the name + % table or manufactured from XUID. + .dicttomark dup % convert keys to dict and copy dict + /FontName fontname put % replace any definition of /FontName + mark exch % put a mark on stack + {} forall % read keys from dict back onto stack + } if .definettcidfont } bind def diff --git a/gs/Resource/Init/pdf_font.ps b/gs/Resource/Init/pdf_font.ps index 04c002515..217ccbb6f 100644 --- a/gs/Resource/Init/pdf_font.ps +++ b/gs/Resource/Init/pdf_font.ps @@ -1006,8 +1006,11 @@ currentdict /eexec_pdf_param_dict .undef true resolvestream readfontfilter % Stack: filepos fontres stream 1 index /Subtype get /CIDFontType2 eq { + 1 index /BaseFont get % Use the BaseFont name for the font. Otherwise we + /PDFCIDFontName exch def % would use the name table, or a manufactured name. .loadttcidfont % Stack: filepos fontres cidfont + currentdict /PDFCIDFontName undef % Remove the name to avoid interference. } { % filepos fontres stream 1 index /FontDescriptor oget % filepos fontres stream fd |