]> granicus.if.org Git - postgresql/commit
Improve our workaround for 'TeX capacity exceeded' in building PDF files.
authorTom Lane <tgl@sss.pgh.pa.us>
Tue, 10 Nov 2015 20:59:59 +0000 (15:59 -0500)
committerTom Lane <tgl@sss.pgh.pa.us>
Tue, 10 Nov 2015 21:00:35 +0000 (16:00 -0500)
commit7fe1d1cfbfaf190ccba576a50214378f6a262325
treec21b44bd6c9f9889b3bc7f178e66128bf14722d6
parent87deb55a4723e3ee00e4324fca684c26cfa17cc6
Improve our workaround for 'TeX capacity exceeded' in building PDF files.

In commit a5ec86a7c787832d28d5e50400ec96a5190f2555 I wrote a quick hack
that reduced the number of TeX string pool entries created while converting
our documentation to PDF form.  That held the fort for awhile, but as of
HEAD we're back up against the same limitation.  It turns out that the
original coding of \FlowObjectSetup actually results in *three* string pool
entries being generated for every "flow object" (that is, potential
cross-reference target) in the documentation, and my previous hack only got
rid of one of them.  With a little more care, we can reduce the string
count to one per flow object plus one per actually-cross-referenced flow
object (about 115000 + 5000 as of current HEAD); that should work until
the documentation volume roughly doubles from where it is today.

As a not-incidental side benefit, this change also causes pdfjadetex to
stop emitting unreferenced hyperlink anchors (bookmarks) into the PDF file.
It had been making one willy-nilly for every flow object; now it's just one
per actually-cross-referenced object.  This results in close to a 2X
savings in PDF file size.  We will still want to run the output through
"jpdftweak" to get it to be compressed; but we no longer need removal of
unreferenced bookmarks, so we might be able to find a quicker tool for
that step.

Although the failure only affects HEAD and US-format output at the moment,
9.5 cannot be more than a few pages short of failing likewise, so it
will inevitably fail after a few rounds of minor-version release notes.
I don't have a lot of faith that we'll never hit the limit in the older
branches; and anyway it would be nice to get rid of jpdftweak across the
board.  Therefore, back-patch to all supported branches.
doc/src/sgml/jadetex.cfg