summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorChris Liddell <chris.liddell@artifex.com>2018-08-28 16:55:49 +0100
committerChris Liddell <chris.liddell@artifex.com>2018-08-28 17:00:41 +0100
commitcef2bf5573eb1312325d33991939d32a46e52ae6 (patch)
treea033cf5379a174e6bad41ee9613a1fdf6fcdf80b
parent520bb0ea7519aa3e79db78aaf0589dae02103764 (diff)
downloadghostpdl-cef2bf5573eb1312325d33991939d32a46e52ae6.tar.gz
Dates, strings and stuff for 9.24 rc1ghostpdl-9.24rc1
-rw-r--r--base/gscdef.c2
-rw-r--r--doc/DLL.htm2
-rw-r--r--doc/Deprecated.htm2
-rw-r--r--doc/Develop.htm2
-rw-r--r--doc/Devices.htm2
-rw-r--r--doc/Drivers.htm2
-rw-r--r--doc/Fonts.htm2
-rw-r--r--doc/History9.htm9895
-rw-r--r--doc/Install.htm2
-rw-r--r--doc/Language.htm2
-rw-r--r--doc/Lib.htm2
-rw-r--r--doc/Make.htm2
-rw-r--r--doc/News.htm4
-rw-r--r--doc/Ps-style.htm2
-rw-r--r--doc/Ps2epsi.htm2
-rw-r--r--doc/Psfiles.htm2
-rw-r--r--doc/Readme.htm2
-rw-r--r--doc/Release.htm2
-rw-r--r--doc/SavedPages.htm2
-rw-r--r--doc/Source.htm2
-rw-r--r--doc/Unix-lpr.htm2
-rw-r--r--doc/Use.htm2
-rw-r--r--doc/VectorDevices.htm2
-rw-r--r--doc/WhatIsGS.htm2
-rw-r--r--doc/gs-vms.hlp2
-rw-r--r--doc/sample_downscale_device.htm2
-rw-r--r--doc/subclass.htm2
-rw-r--r--doc/thirdparty.htm2
-rw-r--r--man/dvipdf.14
-rw-r--r--man/gs.14
-rw-r--r--man/gslp.14
-rw-r--r--man/gsnd.14
-rw-r--r--man/pdf2dsc.14
-rw-r--r--man/pdf2ps.14
-rw-r--r--man/pf2afm.14
-rw-r--r--man/pfbtopfa.14
-rw-r--r--man/printafm.14
-rw-r--r--man/ps2ascii.14
-rw-r--r--man/ps2epsi.14
-rw-r--r--man/ps2pdf.14
-rw-r--r--man/ps2pdfwr.14
-rw-r--r--man/ps2ps.14
42 files changed, 9948 insertions, 59 deletions
diff --git a/base/gscdef.c b/base/gscdef.c
index dfde2b11d..b4ed73c24 100644
--- a/base/gscdef.c
+++ b/base/gscdef.c
@@ -51,7 +51,7 @@ gs_program_family_name(void)
#ifndef GS_PRODUCT
# define GS_PRODUCT\
- GS_PRODUCTFAMILY " GIT PRERELEASE"
+ GS_PRODUCTFAMILY " Release Candidate 1"
#endif
const char *const gs_product = GS_PRODUCT;
diff --git a/doc/DLL.htm b/doc/DLL.htm
index 123bf73bd..af1c8c861 100644
--- a/doc/DLL.htm
+++ b/doc/DLL.htm
@@ -777,7 +777,7 @@ or contact Artifex Software, Inc., 1305 Grant Avenue - Suite 200,
Novato, CA 94945, U.S.A., +1(415)492-9861, for further information.
<p>
-<small>Ghostscript version 9.23, 21 March 2018
+<small>Ghostscript version 9.24, 28 August 2018
<!-- [3.0 end visible trailer] ============================================= -->
diff --git a/doc/Deprecated.htm b/doc/Deprecated.htm
index d079d0266..c7b96d397 100644
--- a/doc/Deprecated.htm
+++ b/doc/Deprecated.htm
@@ -5774,7 +5774,7 @@ or contact Artifex Software, Inc., 1305 Grant Avenue - Suite 200,
Novato, CA 94945, U.S.A., +1(415)492-9861, for further information.
<p>
-<small>Ghostscript version 9.23, 21 March 2018
+<small>Ghostscript version 9.24, 28 August 2018
<!-- [3.0 end visible trailer] ============================================= -->
diff --git a/doc/Develop.htm b/doc/Develop.htm
index 249c09796..4546981a5 100644
--- a/doc/Develop.htm
+++ b/doc/Develop.htm
@@ -4784,7 +4784,7 @@ or contact Artifex Software, Inc., 1305 Grant Avenue - Suite 200,
Novato, CA 94945, U.S.A., +1(415)492-9861, for further information.
<p>
-<small>Ghostscript version 9.23, 21 March 2018
+<small>Ghostscript version 9.24, 28 August 2018
<!-- [3.0 end visible trailer] ============================================= -->
diff --git a/doc/Devices.htm b/doc/Devices.htm
index 49f9e897e..4dcb97632 100644
--- a/doc/Devices.htm
+++ b/doc/Devices.htm
@@ -2005,7 +2005,7 @@ or contact Artifex Software, Inc., 1305 Grant Avenue - Suite 200,
Novato, CA 94945, U.S.A., +1(415)492-9861, for further information.
<p>
-<small>Ghostscript version 9.23, 21 March 2018
+<small>Ghostscript version 9.24, 28 August 2018
<!-- [3.0 end visible trailer] ============================================= -->
diff --git a/doc/Drivers.htm b/doc/Drivers.htm
index adcabd396..7e0dda4e7 100644
--- a/doc/Drivers.htm
+++ b/doc/Drivers.htm
@@ -3604,7 +3604,7 @@ or contact Artifex Software, Inc., 1305 Grant Avenue - Suite 200,
Novato, CA 94945, U.S.A., +1(415)492-9861, for further information.
<p>
-<small>Ghostscript version 9.23, 21 March 2018
+<small>Ghostscript version 9.24, 28 August 2018
<!-- [3.0 end visible trailer] ============================================= -->
diff --git a/doc/Fonts.htm b/doc/Fonts.htm
index 0b103a84a..85767db60 100644
--- a/doc/Fonts.htm
+++ b/doc/Fonts.htm
@@ -358,7 +358,7 @@ or contact Artifex Software, Inc., 1305 Grant Avenue - Suite 200,
Novato, CA 94945, U.S.A., +1(415)492-9861, for further information.
<p>
-<small>Ghostscript version 9.23, 21 March 2018
+<small>Ghostscript version 9.24, 28 August 2018
<!-- [3.0 end visible trailer] ============================================= -->
diff --git a/doc/History9.htm b/doc/History9.htm
index 65ccf3127..5d9dd8d1c 100644
--- a/doc/History9.htm
+++ b/doc/History9.htm
@@ -80,7 +80,8 @@ TOC to see how to edit it for visual conciseness.
<h2>Table of contents</h2>
<blockquote><ul>
-<li><a href="#Version9.22">Version 9.23 (2018-03-21)</a>
+<li><a href="#Version9.24">Version 9.24 (2018-08-28)</a>
+<li><a href="#Version9.23">Version 9.23 (2018-03-21)</a>
<li><a href="#Version9.22">Version 9.22 (2017-10-04)</a>
<li><a href="#Version9.21">Version 9.21 (2017-03-16)</a>
<li><a href="#Version9.20">Version 9.20 (2016-09-26)</a>
@@ -179,7 +180,9895 @@ The planned device API tidy has, unfortunately, been indefinitely postponed, unt
appropriate resources are available.
</li>
</ul>
-<h3><a name="9.22_changelog"></a>Changelog</h3>
+<h3><a name="9.24_changelog"></a>Changelog</h3>
+<p><strong>2018-08-28 16:55:49 +0100
+</strong>
+<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fa11dee6f8a779edbb03ce20853b719f49815fcc">fa11dee6f8a779edbb03ce20853b719f49815fcc</a>
+<blockquote>
+<p>
+ Dates, strings and stuff for 9.24 rc1<br>
+<br>
+base/gscdef.c<br>
+doc/DLL.htm<br>
+doc/Deprecated.htm<br>
+doc/Develop.htm<br>
+doc/Devices.htm<br>
+doc/Drivers.htm<br>
+doc/Fonts.htm<br>
+doc/History9.htm<br>
+doc/Install.htm<br>
+doc/Language.htm<br>
+doc/Lib.htm<br>
+doc/Make.htm<br>
+doc/News.htm<br>
+doc/Ps-style.htm<br>
+doc/Ps2epsi.htm<br>
+doc/Psfiles.htm<br>
+doc/Readme.htm<br>
+doc/Release.htm<br>
+doc/SavedPages.htm<br>
+doc/Source.htm<br>
+doc/Unix-lpr.htm<br>
+doc/Use.htm<br>
+doc/VectorDevices.htm<br>
+doc/WhatIsGS.htm<br>
+doc/gs-vms.hlp<br>
+doc/sample_downscale_device.htm<br>
+doc/subclass.htm<br>
+doc/thirdparty.htm<br>
+man/dvipdf.1<br>
+man/gs.1<br>
+man/gslp.1<br>
+man/gsnd.1<br>
+man/pdf2dsc.1<br>
+man/pdf2ps.1<br>
+man/pf2afm.1<br>
+man/pfbtopfa.1<br>
+man/printafm.1<br>
+man/ps2ascii.1<br>
+man/ps2epsi.1<br>
+man/ps2pdf.1<br>
+man/ps2pdfwr.1<br>
+man/ps2ps.1<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-08-28 16:27:53 +0100
+</strong>
+<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=520bb0ea7519aa3e79db78aaf0589dae02103764">520bb0ea7519aa3e79db78aaf0589dae02103764</a>
+<blockquote>
+<p>
+ Bug #699654 (again) and Bug #699677 Improve operator removal for SAFER<br>
+<br>
+ Take inspiration from the code to remove unused/dangerous operators<br>
+ and, when SAFER is true, remove a bunch more non-standard operators<br>
+ or routines.<br>
+<br>
+ In particular remove the .bindnow operator, which should have been<br>
+ removed previously for Bug #699677 and remove the<br>
+ .pushpdf14devicefilter for Bug #699654. Only the PDF interpreter<br>
+ needs to use that, and the device in question only expects to be used<br>
+ carefully and in the correct sequence. Make sure nobody can meddle with<br>
+ it.<br>
+<br>
+ In addition I removed a number of other operators which are not needed<br>
+ in normal operation. Some of them, however, are useful so these<br>
+ (with the exception of .bindnow which is always removed) are only<br>
+ undefined if SAFER is true.<br>
+<br>
+ This allows our QA procedure to continue to use them, which is<br>
+ particularly important in the case of .makeoperator and .setCPSImode.<br>
+<br>
+ At a later date we may choose to move some of these into the regular<br>
+ undefinition code, ie not dependent on SAFER.<br>
+<br>
+Resource/Init/gs_init.ps<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-08-28 14:53:49 +0100
+</strong>
+<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=21ae2f8d9953ffe8d6c8f1b2bf72a14b54d50e74">21ae2f8d9953ffe8d6c8f1b2bf72a14b54d50e74</a>
+<blockquote>
+<p>
+ Bug 699682: Handle text from single &quot;gs_glyph&quot; or &quot;gs_char&quot;<br>
+<br>
+ In the FAPI code, when dealing a substituted cidfont, we extract the original<br>
+ character code, and decode that using the ToUnicode CMap, in order to get a<br>
+ Unicode code point we can then put through the TTF Unicode cmap table - thus<br>
+ improving the chances of getting a legible result.<br>
+<br>
+ It failed to account for the possiblity that we were dealing with a single<br>
+ character code stored directly, rather than a string of 1 or more codes in a<br>
+ buffer - derefencing an invalid pointer.<br>
+<br>
+ Add code to handle those cases.<br>
+<br>
+psi/zfapi.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-08-28 14:17:09 +0100
+</strong>
+<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7a702103b4490e370b36587c34b8b549a75ef3a5">7a702103b4490e370b36587c34b8b549a75ef3a5</a>
+<blockquote>
+<p>
+ Bug 699678: don't allow bytes to be &quot;unread&quot; from stdin<br>
+<br>
+base/stream.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-08-28 12:13:55 +0100
+</strong>
+<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4b00990640258f464b02ce3f721a22fcb59b289b">4b00990640258f464b02ce3f721a22fcb59b289b</a>
+<blockquote>
+<p>
+ Bug 699676 &quot;PDF interpreter can leave dangerous operators available&quot;<br>
+<br>
+ The problem here is that certain PDF functions require the ability to<br>
+ use some of the non-standard, and dangerous, operators/procedures<br>
+ from the PostScript interpreter.<br>
+<br>
+ If we leave those functions readable then a malicious PostScript program<br>
+ could instantiate the PDF interpreter, inspect the packedarrray and<br>
+ copy the otherwise unobtainable operator/function, then use it for<br>
+ mischief.<br>
+<br>
+ By making the PDF functions executeonly its impossible to read the<br>
+ function contents, which prevents this kind of abuse.<br>
+<br>
+Resource/Init/pdf_base.ps<br>
+Resource/Init/pdf_draw.ps<br>
+Resource/Init/pdf_font.ps<br>
+Resource/Init/pdf_main.ps<br>
+Resource/Init/pdf_ops.ps<br>
+Resource/Init/pdf_rbld.ps<br>
+Resource/Init/pdf_sec.ps<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-08-28 09:55:48 +0100
+</strong>
+<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5b5536fa88a9e885032bc0df3852c3439399a5c0">5b5536fa88a9e885032bc0df3852c3439399a5c0</a>
+<blockquote>
+<p>
+ Remove gssetresolution/gsgetresolution<br>
+<br>
+ These are non-standard, and never used, so remove them.<br>
+<br>
+ Also rejig gsgetdeviceprop, rename to .gsgetdeviceprop and undefine it after<br>
+ it's used.<br>
+<br>
+ For the only other use of gsgetdeviceprop, replace with a special_op call.<br>
+<br>
+Resource/Init/gs_init.ps<br>
+Resource/Init/gs_setpd.ps<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-08-28 07:52:18 +0100
+</strong>
+<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c9b362ba908ca4b1d7c72663a33229588012d7d9">c9b362ba908ca4b1d7c72663a33229588012d7d9</a>
+<blockquote>
+<p>
+ Bug 699670: disallow copying of the epo device<br>
+<br>
+ The erasepage optimisation (epo) subclass device shouldn't be allowed to be<br>
+ copied because the subclass private data, child and parent pointers end up<br>
+ being shared between the original device and the copy.<br>
+<br>
+ Add an epo_finish_copydevice which NULLs the three offending pointers, and<br>
+ then communicates to the caller that copying is not allowed.<br>
+<br>
+ This also exposed a separate issue with the stype for subclasses devices.<br>
+ Devices are, I think, unique in having two stype objects associated with them:<br>
+ the usual one in the memory manager header, and the other stored in the device<br>
+ structere directly. In order for the stype to be correct, we have to use the<br>
+ stype for the incoming device, with the ssize of the original device (ssize<br>
+ should reflect the size of the memory allocation). We correctly did so with the<br>
+ stype in the device structure, but then used the prototype device's stype to<br>
+ patch the memory manager stype - meaning the ssize potentially no longer<br>
+ matched the allocated memory. This caused problems in the garbager where there<br>
+ is an implicit assumption that the size of a single object clump (c_alone == 1)<br>
+ is also the size (+ memory manager overheads) of the single object it contains.<br>
+<br>
+ The solution is to use the same stype instance to patch the memory manager<br>
+ data as we do in the device structure (with the correct ssize).<br>
+<br>
+base/gdevdflt.c<br>
+base/gdevepo.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-08-27 11:15:16 +0100
+</strong>
+<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ea735ba37dc0fd5f5622d031830b9a559dec1cc9">ea735ba37dc0fd5f5622d031830b9a559dec1cc9</a>
+<blockquote>
+<p>
+ Fix error condition for SC and CS<br>
+<br>
+ The SC and CS PDF operators correctly checked the return code from the<br>
+ underlying setcolor and setcolorspace code, but we had already<br>
+ set up the exec stack for handling a non-error return.<br>
+<br>
+ We have to do this before calling the underlying code, as that also<br>
+ uses a state machine, and alters the exec stack. We must push our<br>
+ own execution context first.<br>
+<br>
+ Ordinarily this isn't a problem, but if we have a custom error handler<br>
+ which doesn't stop the interpreter, then we would continue on to try<br>
+ and use what we'd pushed onto the exec stack, with predictably dire<br>
+ results.<br>
+<br>
+ Here we avoid this by saving the exec stack pointer on entry, and if<br>
+ an error occurs, restoring back to that point before returning control<br>
+ to the PostScript interpreter.<br>
+<br>
+ A minor point, but we now also reset the space/color on an error as<br>
+ well, previously it would have been left with the wrong space set.<br>
+<br>
+psi/zcolor.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-08-25 07:45:45 +0100
+</strong>
+<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=79cccf641486a6595c43f1de1cd7ade696020a31">79cccf641486a6595c43f1de1cd7ade696020a31</a>
+<blockquote>
+<p>
+ Bug 699654(2): preserve LockSafetyParams in the nulldevice<br>
+<br>
+ The nulldevice does not necessarily use the normal setpagedevice machinery,<br>
+ but can be set using the nulldevice operator. In which case, we don't preserve<br>
+ the settings from the original device (in the way setpagedevice does).<br>
+<br>
+ Since nulldevice does nothing, this is not generally a problem, but in the case<br>
+ of LockSafetyParams it *is* important when we restore back to the original<br>
+ device, when LockSafetyParams not being set is &quot;preserved&quot; into the post-<br>
+ restore configuration.<br>
+<br>
+ We have to initialise the value to false because the nulldevice is used during<br>
+ initialisation (before any other device exists), and *must* be writable for<br>
+ that.<br>
+<br>
+base/gsdevice.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-08-24 18:17:50 +0100
+</strong>
+<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e5b46839994ec093251bb641fb7cbffe81712e40">e5b46839994ec093251bb641fb7cbffe81712e40</a>
+<blockquote>
+<p>
+ Fix a typo in a dependency<br>
+<br>
+psi/int.mak<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-08-24 09:26:04 +0100
+</strong>
+<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5516c614dc33662a2afdc377159f70218e67bde5">5516c614dc33662a2afdc377159f70218e67bde5</a>
+<blockquote>
+<p>
+ Improve restore robustness<br>
+<br>
+ Prompted by looking at Bug 699654:<br>
+<br>
+ There are two variants of the restore operator in Ghostscript: one is Level 1<br>
+ (restoring VM), the other is Level 2+ (adding page device restoring to the<br>
+ Level operator).<br>
+<br>
+ This was implemented by the Level 2+ version restoring the device in the<br>
+ graphics state, then calling the Level 1 implementation to handle actually<br>
+ restoring the VM state.<br>
+<br>
+ The problem was that the operand checking, and sanity of the save object was<br>
+ only done by the Level 1 variant, thus meaning an invalid save object could<br>
+ leave a (Level 2+) restore partially complete - with the page device part<br>
+ restored, but not VM, and the page device not configured.<br>
+<br>
+ To solve that, this commit splits the operand and sanity checking, and the<br>
+ core of the restore operation into separate functions, so the relevant<br>
+ operators can validate the operand *before* taking any further action. That<br>
+ reduces the chances of an invalid restore leaving the interpreter in an<br>
+ unknown state.<br>
+<br>
+ If an error occurs during the actual VM restore it is essentially fatal, and the<br>
+ interpreter cannot continue, but as an extra surety for security, in the event<br>
+ of such an error, we'll explicitly preserve the LockSafetyParams of the device,<br>
+ rather than rely on the post-restore device configuration (which won't happen<br>
+ in the event of an error).<br>
+<br>
+psi/int.mak<br>
+psi/isave.h<br>
+psi/zdevice2.c<br>
+psi/zvmem.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-08-24 12:59:45 +0100
+</strong>
+<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b0a3854751363657998d4c9bd33c290bf9d07c67">b0a3854751363657998d4c9bd33c290bf9d07c67</a>
+<blockquote>
+<p>
+ Improve PDF operator hiding<br>
+<br>
+ Firstly, hide the .setdistillerparams operator, if we try to use this<br>
+ with a device which doesn't accept distiller params it could cause<br>
+ problems. The setdistillerparams operator checks the device before<br>
+ calling .setdistillerparams. This change is needed in *both*<br>
+ pdf_main.ps and gs_init.ps (see next)<br>
+<br>
+ Secondly, fix the code for hiding PDF operators, when DELAYBIND is<br>
+ true. We can't undefine the operators in pdf_main.ps if DELAYBIND<br>
+ is true, because the procedures using them won't have been bound yet.<br>
+ So we duplicate the code for removing the operators in gs_init.ps<br>
+ and call that during .bindnow, after all the deferred binding has been<br>
+ completed.<br>
+<br>
+ Previously the code for hiding the PDF and PostScript operators had been<br>
+ left commented out, meaning that if a user chose DELAYBIND (which is<br>
+ itself a massive security hole) then this minor layer of security<br>
+ would not have been activated.<br>
+<br>
+Resource/Init/gs_init.ps<br>
+Resource/Init/pdf_main.ps<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-08-24 12:44:26 +0100
+</strong>
+<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e01e77a36cbb2e0277bc3a63852244bec41be0f6">e01e77a36cbb2e0277bc3a63852244bec41be0f6</a>
+<blockquote>
+<p>
+ Hide the .shfill operator<br>
+<br>
+ Commit 0b6cd1918e1ec4ffd087400a754a845180a4522b was supposed to make<br>
+ the .shfill operator unobtainable, but I accidentally left a comment<br>
+ in the line doing so.<br>
+<br>
+ Fix it here, without this the operator can still be exploited.<br>
+<br>
+Resource/Init/gs_init.ps<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-08-23 15:42:02 +0100
+</strong>
+<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8e9ce5016db968b40e4ec255a3005f2786cce45f">8e9ce5016db968b40e4ec255a3005f2786cce45f</a>
+<blockquote>
+<p>
+ Bug 699665 &quot;memory corruption in aesdecode&quot;<br>
+<br>
+ The specimen file calls aesdecode without specifying the key to be<br>
+ used, though it does manage to do enough work with the PDF interpreter<br>
+ routines to get access to aesdecode (which isn't normally available).<br>
+<br>
+ This causes us to read uninitialised memory, which can (and often does)<br>
+ lead to a segmentation fault.<br>
+<br>
+ In this commit we set the key to NULL explicitly during intialisation<br>
+ and then check it before we read it. If its NULL we just return.<br>
+<br>
+ It seems bizarre that we don't return error codes, we should probably<br>
+ look into that at some point, but this prevents the code trying to<br>
+ read uninitialised memory.<br>
+<br>
+base/aes.c<br>
+base/saes.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-08-23 15:41:18 +0100
+</strong>
+<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=241d91112771a6104de10b3948c3f350d6690c1d">241d91112771a6104de10b3948c3f350d6690c1d</a>
+<blockquote>
+<p>
+ Bug 699664: Ensure the correct is in place before cleanup<br>
+<br>
+ If the PS job replaces the device and leaves that graphics state in place, we<br>
+ wouldn't cleanup the default device in the normal way, but rely on the garbage<br>
+ collector.<br>
+<br>
+ This works (but isn't ideal), *except* when the job replaces the device with<br>
+ the null device (using the nulldevice operator) - this means that<br>
+ .uninstallpagedevice doesn't replace the existing device with the nulldevice<br>
+ (since it is already installed), the device from the graphics ends up being<br>
+ freed - and as it is the nulldevice, which we rely on, memory corruption<br>
+ and a segfault can happen.<br>
+<br>
+ We avoid this by checking if the current device is the nulldevice, and if so,<br>
+ restoring it away, before continuing with the device cleanup.<br>
+<br>
+psi/imain.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-08-23 14:13:25 +0100
+</strong>
+<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c432131c3fdb2143e148e8ba88555f7f7a63b25e">c432131c3fdb2143e148e8ba88555f7f7a63b25e</a>
+<blockquote>
+<p>
+ Bug 699661: Avoid sharing pointers between pdf14 compositors<br>
+<br>
+ If a copdevice is triggered when the pdf14 compositor is the device, we make<br>
+ a copy of the device, then throw an error because, by default we're only allowed<br>
+ to copy the device prototype - then freeing it calls the finalize, which frees<br>
+ several pointers shared with the parent.<br>
+<br>
+ Make a pdf14 specific finish_copydevice() which NULLs the relevant pointers,<br>
+ before, possibly, throwing the same error as the default method.<br>
+<br>
+ This also highlighted a problem with reopening the X11 devices, where a custom<br>
+ error handler could be replaced with itself, meaning it also called itself,<br>
+ and infifite recursion resulted.<br>
+<br>
+ Keep a note of if the handler replacement has been done, and don't do it a<br>
+ second time.<br>
+<br>
+base/gdevp14.c<br>
+devices/gdevxini.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-08-23 14:12:48 +0100
+</strong>
+<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0b6cd1918e1ec4ffd087400a754a845180a4522b">0b6cd1918e1ec4ffd087400a754a845180a4522b</a>
+<blockquote>
+<p>
+ Fix Bug 699660 &quot;shading_param incomplete type checking&quot;<br>
+<br>
+ Its possible to pass a t_struct parameter to .shfill which is not a<br>
+ shading function built by .buildshading. This could then lead to memory<br>
+ corruption or a segmentation fault by treating the object passed in<br>
+ as if it were a shading.<br>
+<br>
+ Its non-trivial to check the t_struct, because this function can take<br>
+ 7 different kinds of structures as a parameter. Checking these is<br>
+ possible, of course, but would add a performance penalty.<br>
+<br>
+ However, we can note that we never call .shfill without first calling<br>
+ .buildshading, and we never call .buildshading without immediately<br>
+ calling .shfill. So we can treat these as an atomic operation. The<br>
+ .buildshading function takes all its parameters as PostScript objects<br>
+ and validates them, so that should be safe.<br>
+<br>
+ This allows us to 'hide' the .shfill operator preventing the possibility<br>
+ of passing an invalid parameter.<br>
+<br>
+Resource/Init/gs_init.ps<br>
+Resource/Init/gs_ll3.ps<br>
+Resource/Init/pdf_draw.ps<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-08-23 12:20:56 +0100
+</strong>
+<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b575e1ec42cc86f6a58c603f2a88fcc2af699cc8">b575e1ec42cc86f6a58c603f2a88fcc2af699cc8</a>
+<blockquote>
+<p>
+ Bug 699668: handle stack overflow during error handling<br>
+<br>
+ When handling a Postscript error, we push the object throwing the error onto<br>
+ the operand stack for the error handling procedure to access - we were not<br>
+ checking the available stack before doing so, thus causing a crash.<br>
+<br>
+ Basically, if we get a stack overflow when already handling an error, we're out<br>
+ of options, return to the caller with a fatal error.<br>
+<br>
+psi/interp.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-08-23 09:30:56 +0100
+</strong>
+<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d224b4abec1d0bd991028b7e38e95d47b7a834f4">d224b4abec1d0bd991028b7e38e95d47b7a834f4</a>
+<blockquote>
+<p>
+ Bug 699623: ICC profile creation file permissions check<br>
+<br>
+ The original fix missed the initial branch with an explicitly specified<br>
+ directory.<br>
+<br>
+ This also uncovered problems with device profile reference counting, where<br>
+ if profile creation failed we'd leave a pointer to the original profile<br>
+ in place - either a dangling pointer, or leaving the ref count wrong.<br>
+<br>
+ To solve this, we NULL the relevant profile pointer in the device after<br>
+ adjusting the reference count.<br>
+<br>
+base/gsicc_manage.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-08-23 09:54:59 +0100
+</strong>
+<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=78911a01b67d590b4a91afac2e8417360b934156">78911a01b67d590b4a91afac2e8417360b934156</a>
+<blockquote>
+<p>
+ Bug 699654: Check the restore operand type<br>
+<br>
+ The primary function that implements restore correctly checked its parameter,<br>
+ but a function that does some preliminary work for the restore (gstate and<br>
+ device handling) did not check.<br>
+<br>
+ So, even though the restore correctly errored out, it left things partially done<br>
+ and, in particular, the device in partially restored state. Meaning the<br>
+ LockSafetyParams was not correctly set.<br>
+<br>
+psi/zdevice2.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-08-21 20:36:52 +0100
+</strong>
+<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0edd3d6c634a577db261615a9dc2719bca7f6e01">0edd3d6c634a577db261615a9dc2719bca7f6e01</a>
+<blockquote>
+<p>
+ Bug 699659: Don't just assume an object is a t_(a)struct<br>
+<br>
+psi/ztype.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-08-21 20:17:51 +0100
+</strong>
+<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a054156d425b4dbdaaa9fda4b5f1182b27598c2b">a054156d425b4dbdaaa9fda4b5f1182b27598c2b</a>
+<blockquote>
+<p>
+ Bug 699658: Fix handling of pre-SAFER opened files.<br>
+<br>
+ Temp files opened for writing before SAFER is engaged are not subject to the<br>
+ SAFER restrictions - that is handled by recording in a dictionary, and<br>
+ checking that as part of the permissions checks.<br>
+<br>
+ By adding a custom error handler for invalidaccess, that allowed the filename<br>
+ to be added to the dictionary (despite the attempted open throwing the error)<br>
+ thus meaning subsequent accesses were erroneously permitted.<br>
+<br>
+Resource/Init/gs_init.ps<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-08-21 20:17:05 +0100
+</strong>
+<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0d3901189f245232f0161addf215d7268c4d05a3">0d3901189f245232f0161addf215d7268c4d05a3</a>
+<blockquote>
+<p>
+ Bug 699657: properly apply file permissions to .tempfile<br>
+<br>
+psi/zfile.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-08-21 16:42:45 +0100
+</strong>
+<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c3476dde7743761a4e1d39a631716199b696b880">c3476dde7743761a4e1d39a631716199b696b880</a>
+<blockquote>
+<p>
+ Bug 699656: Handle LockDistillerParams not being a boolean<br>
+<br>
+ This caused a function call commented as &quot;Can't fail&quot; to fail, and resulted<br>
+ in memory correuption and a segfault.<br>
+<br>
+devices/vector/gdevpdfp.c<br>
+psi/iparam.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-08-21 16:24:05 +0100
+</strong>
+<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b326a71659b7837d3acde954b18bda1a6f5e9498">b326a71659b7837d3acde954b18bda1a6f5e9498</a>
+<blockquote>
+<p>
+ Bug 699655: Properly check the return value....<br>
+<br>
+ ...when getting a value from a dictionary<br>
+<br>
+psi/zcolor.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-08-15 16:24:11 +0100
+</strong>
+<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f25045e88de674a1202c1239565ee99e9ddabe91">f25045e88de674a1202c1239565ee99e9ddabe91</a>
+<blockquote>
+<p>
+ Fix missing dependency declaration for gdevoflt.h<br>
+<br>
+base/lib.mak<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-08-20 15:18:27 +0100
+</strong>
+<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=50ef2aa8c28f0eb097b8dab3effbe6b1c3948879">50ef2aa8c28f0eb097b8dab3effbe6b1c3948879</a>
+<blockquote>
+<p>
+ Fix &quot;ignored return code&quot; Coverity errors.<br>
+<br>
+ Several places in pl_main_process_options(), we were ignoring return codes -<br>
+ particularly, cases where a genuine error is possible.<br>
+<br>
+ Rather than handle each error case automatically, drop out of the switch,<br>
+ and catch the error before jumping to the top of the while loop.<br>
+<br>
+ For consistency, ignore the error triggered by -dBATCH<br>
+<br>
+pcl/pl/plmain.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-08-20 19:03:26 +0100
+</strong>
+<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=678261f0d973badfc4609e9e7b27a1d039609ebb">678261f0d973badfc4609e9e7b27a1d039609ebb</a>
+<blockquote>
+<p>
+ PostScrip ICC spaces - fix minor memory leak<br>
+<br>
+psi/zicc.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-08-18 17:12:46 +0100
+</strong>
+<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4ade82d9471971937ff3bcb39823cb080a18c2d5">4ade82d9471971937ff3bcb39823cb080a18c2d5</a>
+<blockquote>
+<p>
+ Fix a minor compiler warning<br>
+<br>
+devices/gdevdsp.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-08-18 10:44:52 +0100
+</strong>
+<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6b1106c232bb18366c527f9da54715ac79165317">6b1106c232bb18366c527f9da54715ac79165317</a>
+<blockquote>
+<p>
+ Fix display device (some more) with subclassing<br>
+<br>
+ Because the display device isn't based off one of the standard devices<br>
+ we need to do extra work with it to ensure it behaves well with the<br>
+ subclassing device code.<br>
+<br>
+ Commit 1203adc8bbcb60f0e4145300aac44f1988b7c2de contained some of this<br>
+ work, but unfortunately it had an oversight, it didn't update the<br>
+ parent (subclassing) devices when the device parameters changed.<br>
+<br>
+ This led to it using the wrong width for the raster, if the media<br>
+ size changed after initialisation.<br>
+<br>
+devices/gdevdsp.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-08-15 13:44:53 -0600
+</strong>
+<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c265ee6563a1a65d225c4255d95d7306a21c3146">c265ee6563a1a65d225c4255d95d7306a21c3146</a>
+<blockquote>
+<p>
+ Token buffer not freed.<br>
+<br>
+ Unrecognized PJL settings resulted in a memory leak of the token<br>
+ buffer.<br>
+<br>
+pcl/pl/pjparse.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-08-15 10:45:50 -0700
+</strong>
+<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fa9b0f51a5fbac1bdabef012cc5b0ca006c2c281">fa9b0f51a5fbac1bdabef012cc5b0ca006c2c281</a>
+<blockquote>
+<p>
+ Fix compiler warning<br>
+<br>
+base/gdevepo.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-08-15 14:10:55 +0100
+</strong>
+<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7ab21af0b0c70707aefb1083505136ff7862d337">7ab21af0b0c70707aefb1083505136ff7862d337</a>
+<blockquote>
+<p>
+ Bug 699638(3): Fix param list key handling in pl_main_process_options()<br>
+<br>
+ param lists can be configured to handle keys in two ways: persistent keys, or<br>
+ transient keys. For persistent keys, the param list contains a reference to the<br>
+ key string, and does no management of the string memory.<br>
+<br>
+ Configured for transient key strings, the param list makes a copy of the string<br>
+ and the string memory is managed along with the parameter list itself.<br>
+<br>
+ The two approaches cannot be mixed in the same param list.<br>
+<br>
+ The pl_main_process_options() code configures the param list to use transient<br>
+ key strings (which is the default). But it was then copying the key strings,<br>
+ before passing them to the param list API, and taking no action to manage<br>
+ the string memory - causing memory leaks.<br>
+<br>
+ Since the param list (as configured) takes a copy of the key string, there's no<br>
+ call for the calling code to do so, and not doing the local string copy<br>
+ prevents leaking memory.<br>
+<br>
+pcl/pl/plmain.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-08-15 09:30:09 +0100
+</strong>
+<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1ff8b85ae28c7813aa484dd8f1779f4a4d0742af">1ff8b85ae28c7813aa484dd8f1779f4a4d0742af</a>
+<blockquote>
+<p>
+ Bug 699638(2): correct reference counts in gs_initgraphics<br>
+<br>
+ In gs_initgraphics(), when we create new color spaces for the graphics state<br>
+ the color space is created with a reference count of 1, we then call<br>
+ gs_setcolorspace() which attaches the color space to the gstate and increments<br>
+ the reference count - we then drop the &quot;local&quot; reference, leaving a<br>
+ reference count of 2, but only a single reference to the color space (the one<br>
+ in the graphics state). Meaning the memory leaks.<br>
+<br>
+ So, decrement the reference count for the local reference, before dropping the<br>
+ local reference.<br>
+<br>
+base/gsstate.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-08-15 08:37:38 +0100
+</strong>
+<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=854f14096c0c6467068701ad19c4c775374e1ce4">854f14096c0c6467068701ad19c4c775374e1ce4</a>
+<blockquote>
+<p>
+ Bug 699638(1): Clean up before early exit in gx_image_cached_char()<br>
+<br>
+ If we end up using the imagemask method to render a cached glyph, we can drop<br>
+ out early if the glyph is outside the current clip. Previously, the function<br>
+ simply returned at that point, leaking memory.<br>
+<br>
+ Now it falls through to the cleanup and normal return, no longer leaking.<br>
+<br>
+base/gxccache.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-08-14 10:01:08 -0700
+</strong>
+<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1fe06b350370a51d1bcccde37f8daf13af803d3c">1fe06b350370a51d1bcccde37f8daf13af803d3c</a>
+<blockquote>
+<p>
+ Change the debugging in epo to use the gs_debug stuff<br>
+<br>
+ I am using 3 flags -- epo-details, epo-install-only, epo-disable.<br>
+<br>
+ Can also call &quot;epo_disable(1)&quot; during a gdb session to turn on/off<br>
+ during the session.<br>
+<br>
+base/gdbflags.h<br>
+base/gdevepo.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-08-09 07:56:51 -0700
+</strong>
+<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=df188f54f3e3eed5f12b921440ac7d29970aba35">df188f54f3e3eed5f12b921440ac7d29970aba35</a>
+<blockquote>
+<p>
+ Bug 690131: Add epo subclass device to do erasepage optimization.<br>
+<br>
+ This optimization only works for devices that have a fillpage<br>
+ implementation that is &quot;gx_default_fillpage&quot;. For other devices the<br>
+ subclass device will not be installed. If the device transitions to<br>
+ clist (or any other non-gx_default_fillpage device), we will stop<br>
+ doing the optimization.<br>
+<br>
+ The optimization basically swallows(defers) all fillpages, remembering<br>
+ the color (which is probably always white, but it will work with any<br>
+ &quot;pure&quot; color). Then when the first actual marking operation happens,<br>
+ we do a fill_rectangle operation with the remembered color.<br>
+<br>
+base/gdevepo.c<br>
+base/gdevepo.h<br>
+base/gspaint.c<br>
+base/lib.mak<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-08-09 11:25:57 +0100
+</strong>
+<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=428c05bf7168df79721f9bf3c574ccd9e1294e7e">428c05bf7168df79721f9bf3c574ccd9e1294e7e</a>
+<blockquote>
+<p>
+ Fix a couple of compiler warnings<br>
+<br>
+ Part of the subclassing updates.<br>
+<br>
+devices/vector/gdevpdfo.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-08-09 11:25:57 +0100
+</strong>
+<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=55cb739c1134882c6abaca6264a8d8bccf24dedf">55cb739c1134882c6abaca6264a8d8bccf24dedf</a>
+<blockquote>
+<p>
+ Fix a couple of compiler warnings<br>
+<br>
+ Part of the subclassing updates.<br>
+<br>
+devices/gdevdsp.c<br>
+devices/vector/gdevpdfo.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-07-31 16:36:28 +0100
+</strong>
+<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5f8ac1413077051fd0f559b7b2d5f36b10d58bfe">5f8ac1413077051fd0f559b7b2d5f36b10d58bfe</a>
+<blockquote>
+<p>
+ Device Subclassing - fix memory leak of the 'stype' device member<br>
+<br>
+ This is all horribly crufty and really not possible to explain.<br>
+<br>
+ With the addition of the custom finalize() for subclassing devices we<br>
+ sorted this out for the case where all the devices were garbage<br>
+ collected (the GC, the custom finalize and the device finalize take<br>
+ care of all the wrinkles here).<br>
+<br>
+ But for unsubclassing we cannot use the finalize() routine for the<br>
+ original device when freeing the child. For most devices this does<br>
+ actually work, but if the device itself has a custom finalize method<br>
+ (rare, but see psdcmyk) then if we allow the finalize routine to run<br>
+ it might (and in the case of psdcmyk does) free memory which is still<br>
+ being pointed at by the parent (original) device structure.<br>
+<br>
+ So we need to NULL the finalize routine in the stype structure, tell<br>
+ the memory manager to use the newly modified structure, then free the<br>
+ child device memory and finally free the stype structure.<br>
+<br>
+ We also need to properly handle the reference counts of the icc_struct<br>
+ and PagesList objects, but we had done that already in previous commits.<br>
+<br>
+ For safety, set the parent and child pointers to NULL and set the child<br>
+ device structure reference count to 0 to ensure it is not retained.<br>
+<br>
+ Finally; there was a minor error when patching back the memory manager<br>
+ 'stype' copy in the parent device, fix that now too.<br>
+<br>
+base/gdevdflt.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-07-27 12:17:32 +0100
+</strong>
+<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1203adc8bbcb60f0e4145300aac44f1988b7c2de">1203adc8bbcb60f0e4145300aac44f1988b7c2de</a>
+<blockquote>
+<p>
+ Device subclassing - synchronise devices on put_params<br>
+<br>
+ Commit 434fb65601b91e14fe4f846dcbb92a68d939faf9 on the erasepage<br>
+ branch fixed the initial problem, but was not a sufficient solution.<br>
+<br>
+ While it seems correct to update the 'target' of the clist so that it<br>
+ points to the head of the subclassing chain, we can run into problems<br>
+ using that device, if its parameters (eg width and height) do not<br>
+ match the ultimate device.<br>
+<br>
+ This can happen if we get a put_params() which alters the device<br>
+ parameters. Although we update the chain after the put_params has<br>
+ completed, gdevprn-derived devices will reallocate memory or<br>
+ re-initialise the clist *during* the course of the put_params. If we<br>
+ don't resynchronise the chain but do update the clist target, then the<br>
+ clist re-initialisation will be using the wrong parameters.<br>
+<br>
+base/gdevprn.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-07-26 17:39:40 +0100
+</strong>
+<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9cb7fbd8ca2f2dee6652d832c76da16b85a5f730">9cb7fbd8ca2f2dee6652d832c76da16b85a5f730</a>
+<blockquote>
+<p>
+ Device Subclassing - fix memory leaks with child device<br>
+<br>
+ We should not patch out the finalize routine (now that we have a custom<br>
+ one), that prevents the child device finalize being run, leading to<br>
+ memory leaks with ICC profiles.<br>
+<br>
+ Also, now we have a finalize routine, we need to free the child device<br>
+ if there is one present. The child device's own finalize routine will<br>
+ clean everything up.<br>
+<br>
+base/gdevdflt.c<br>
+base/gdevsclass.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-07-26 16:03:30 +0100
+</strong>
+<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=12a188d18097e2161f3d653b677e55f558d57faf">12a188d18097e2161f3d653b677e55f558d57faf</a>
+<blockquote>
+<p>
+ Device Subclassing - add a finalize routine for subclassing devices<br>
+<br>
+ After some research its clear that subclassing devices do actually need<br>
+ their own specific finalize routine, borrowing the device finalize<br>
+ leads to problems.<br>
+<br>
+ So here we define a default version. All subclassing devices should<br>
+ either use this routine, or implement their own of the allocate additional<br>
+ memory. In that case the specific finalize routine should clean up its<br>
+ own memory and then call the default one.<br>
+<br>
+ Add default subclassing finalize to system devices<br>
+<br>
+base/gdevflp.c<br>
+base/gdevmplt.c<br>
+base/gdevoflt.c<br>
+base/gdevsclass.c<br>
+base/gdevsclass.h<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-07-17 12:45:20 +0100
+</strong>
+<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ae5fddd0bd7b06215235090470d3f9297faa24bb">ae5fddd0bd7b06215235090470d3f9297faa24bb</a>
+<blockquote>
+<p>
+ Subclassing - correct reference counts on ICC profiles<br>
+<br>
+ We weren't previously reference counting the profile structure, this<br>
+ wasn't a problem until pdfwrite started honouring /ProcessColorModel<br>
+ requests in setpagedevice, which could lead to the ICC profile<br>
+ structure altering between the device being subclassed, and the<br>
+ device being unsubclassed.<br>
+<br>
+base/gdevdflt.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-07-17 10:08:33 +0100
+</strong>
+<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2642d19883e4c008f999f2872cc0a37b2268634e">2642d19883e4c008f999f2872cc0a37b2268634e</a>
+<blockquote>
+<p>
+ Fix the display device with subclassing devices<br>
+<br>
+ When the display device is chosen, the executable calls display_set_callbacks<br>
+ on the current device. That code then sets a member in the current<br>
+ device, *without* checking the device is actually the display device.<br>
+<br>
+ It does this *before* opening the device....<br>
+<br>
+ This is a quick hack to resolve the problem by descending to the bottom<br>
+ child device if there is a chain of devices in place. We should really<br>
+ check the device name at each step.<br>
+<br>
+ In addition the Windows display device keeps a pointer to the device along<br>
+ with each 'image'. Not sure why, but it breaks if we are using device<br>
+ subclassing, because the device can change.<br>
+<br>
+ Finally; the code doesn't cope with being unable to find a matching<br>
+ image with the same device. It sets the 'img' to NULL and then goes ahead<br>
+ and tries to use it anyway. Fix that at the same time so we don't crash!<br>
+<br>
+devices/gdevdsp.c<br>
+psi/dwmain.c<br>
+psi/idisp.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-07-16 16:02:26 +0100
+</strong>
+<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8c0d309e74526e0eb5152af05067a9b0a53892c7">8c0d309e74526e0eb5152af05067a9b0a53892c7</a>
+<blockquote>
+<p>
+ pdfwrite - fix stored device pointers in streams, when subclassing<br>
+<br>
+ Yet more evidence of nasty hackery in pdfwrite. It stores a copy of the<br>
+ device pointer in the pdf stream_state. Of course, if we had a<br>
+ subclassed device when we created the stream, and unsubclassed it before<br>
+ we closed the (eg if we create a high level pattern before the first<br>
+ marking operation) then the stored pointer was pointing at the wrong<br>
+ (child, freed) device.<br>
+<br>
+ Just do some pointer traversal to make sure we store the top level one<br>
+ and use the bottom level one when we need it.<br>
+<br>
+devices/vector/gdevpdfo.c<br>
+devices/vector/gdevpsds.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-07-16 15:58:35 +0100
+</strong>
+<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=40b7e425f7ba239e4639baf3feb9d54ebbb85957">40b7e425f7ba239e4639baf3feb9d54ebbb85957</a>
+<blockquote>
+<p>
+ device subclassing - solve several problems with short-lived subclassing<br>
+<br>
+ Nancy's new erasepage optimisation code revealed some interesting<br>
+ wrinkles in the subclassing code, Firstly;<br>
+<br>
+ If we did a save, then inserted a subclassing device, then a restore<br>
+ we would get a segmentation fault.<br>
+<br>
+ This is because when we subclass a device, we make a new copy of the<br>
+ original device. This device is, of course, created inside the current<br>
+ save context. When we restore, that restores away the copied device<br>
+ with the result that the 'child' pointer of the original device is now<br>
+ pointing at garbage memory.<br>
+<br>
+ Fix this by using 'stable' memory instead of immovable memory. Stable<br>
+ memory is unaffected by save and restore.<br>
+<br>
+ This means we also need to 'null' the members of the copied child when<br>
+ we 'unsubclass' the device. Otherwise garbage collection may end up<br>
+ trying to enumerate the pointers in the freed device.<br>
+<br>
+ Following on from that, when we get a create_compositor call in the<br>
+ subclassing code we do a dance whereby we patch the method in the<br>
+ compositor handler that gets pushed, so that it points to the subclass<br>
+ device, not the device's ultimate child. Of course, when we unsubclass<br>
+ the device, we need to unpatch the compositor as well.<br>
+<br>
+ That one may need more work.<br>
+<br>
+ Finally (for now) we weren't properly handling the parent and child<br>
+ pointers for the list when we removed a device from the middle of a<br>
+ chain. The doubly-linked pointers weren't being properly updated.<br>
+<br>
+base/gdevdflt.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-07-14 10:22:45 +0100
+</strong>
+<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=39e8e61d79488909b7645ecc31563ce15aa05702">39e8e61d79488909b7645ecc31563ce15aa05702</a>
+<blockquote>
+<p>
+ Fix subclassing and page buffer reallocation in prn devices<br>
+<br>
+ It is possible for us to need to reallocate the page buffer for a<br>
+ device if (or example) a setpagedevice call results in changed width<br>
+ or height of the media.<br>
+<br>
+ When we do that, if we need to change to (or re-initialise) a clist<br>
+ then we set the clist 'target' member to be the 'current' device. That<br>
+ doesn't mean the current device in the graphics state though, if<br>
+ we have subclassed the device then we will have passed the params<br>
+ request down the chain, so the rendering device is not the current<br>
+ device in the gstate.<br>
+<br>
+ We need the target of the clist to be the subclassing device, ie the<br>
+ one in the graphics state, not the 'current' one. Otherwise if we<br>
+ were to unsubclass the device, then the clist would be pointing at a<br>
+ device which was freed.<br>
+<br>
+ There's no good way to do this from the subclassing code itself, so<br>
+ I have (reluctantly) modified gdevprn.c to handle this. Any devices<br>
+ which don't derive from gdevprn, and use the clist, will need to handle<br>
+ this case themselves.<br>
+<br>
+base/gdevprn.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-07-14 10:15:34 +0100
+</strong>
+<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8eb6643606556921bbbbf495825470cd75123874">8eb6643606556921bbbbf495825470cd75123874</a>
+<blockquote>
+<p>
+ subclassing devices - fix clist patching on unsubclass<br>
+<br>
+ When removing a subclassing device from the chain, if we have patched<br>
+ the clist create_compositor method, then we need to restore it,<br>
+ otherwise it will continue to point to the (now vanished) subnclassing<br>
+ device's method.<br>
+<br>
+base/gdevdflt.c<br>
+base/gdevsclass.c<br>
+base/gxdevice.h<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-08-09 11:55:54 +0100
+</strong>
+<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=88c54234ef0565e54de8b2378907ca201f348b4b">88c54234ef0565e54de8b2378907ca201f348b4b</a>
+<blockquote>
+<p>
+ Update &quot;Font lookup&quot; description<br>
+<br>
+ The FONTPATH section did not explicitly state the search includes descendants<br>
+ of the directories listed in FONTPATH.<br>
+<br>
+ Possibly this is because filenameforall (with which the search is implemented)<br>
+ did not recurse into subdirectories when the FONTPATH feature was originally<br>
+ added, but filenameforall now does (as it is supposed to), so the docs should<br>
+ reflect that.<br>
+<br>
+doc/Use.htm<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-08-06 11:31:11 +0100
+</strong>
+<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=398fd3742abf40cd1c4b94273e81755bdcb5e88f">398fd3742abf40cd1c4b94273e81755bdcb5e88f</a>
+<blockquote>
+<p>
+ PDF interpreter remove debug code<br>
+<br>
+ Accidentally left a 'pstack' in the last commit<br>
+<br>
+Resource/Init/pdf_draw.ps<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-08-06 11:23:00 +0100
+</strong>
+<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=17d6b5fd47e161b8a0bfd23e7a4214b16acd07dd">17d6b5fd47e161b8a0bfd23e7a4214b16acd07dd</a>
+<blockquote>
+<p>
+ PDF interpreter - resurrect Link handling improvements<br>
+<br>
+ commit 61f53ab8f9e586c8722ccd0ea7de3722b0d40cd2 removed the duplication<br>
+ of /Link and /Text annotation handling, and used the newer code for<br>
+ handling these instead.<br>
+<br>
+ It transpires that the /Link handling in the old (removed) code was<br>
+ considerably more functional than that in the newer code...<br>
+<br>
+ Here we replace the new code with the old code in order to get the same<br>
+ functionality, but with the proper controls in place, and only handling<br>
+ annotations in one place instead of 2.<br>
+<br>
+Resource/Init/pdf_draw.ps<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-08-06 09:37:32 +0100
+</strong>
+<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=61f53ab8f9e586c8722ccd0ea7de3722b0d40cd2">61f53ab8f9e586c8722ccd0ea7de3722b0d40cd2</a>
+<blockquote>
+<p>
+ PDF interpreter - Remove old annotation handling for pdfwrite<br>
+<br>
+ Bug #699619 &quot;Annotations included twice with pdfwrite&quot;<br>
+<br>
+ At some point in the past we handled a very few annotations with<br>
+ pdfwrite and did so in the pdfshowpage_finish routine. Since then we<br>
+ have moved the handling of annotations for pdfwrite into the<br>
+ showpagecontents routine, along with regular annotation rendering.<br>
+<br>
+ But leaving the old code in place meant that some annotations (/Link<br>
+ and /Text) were being processed twice (for pdfwrite). Additionally<br>
+ the old code didn't honour the ShowAnnots or PreserveAnnots controls.<br>
+<br>
+ Just remove the old code.<br>
+<br>
+Resource/Init/pdf_main.ps<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-08-03 21:36:26 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1c12d01a2fb48e5fc69f46318348a4ad641be131">1c12d01a2fb48e5fc69f46318348a4ad641be131</a>
+<blockquote>
+<p>
+ Revert accidentally pushed &quot;WIP: gitignore&quot;<br>
+<br>
+ This reverts commit 3f6507e834e92d9f5fc07ec8e91509a54ce9ec6d.<br>
+<br>
+.gitignore<br>
+jbig2dec/.gitignore<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-08-03 10:48:55 +0100
+</strong>
+<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3bf4f3ea45f0022b6cd36415f095f1bfc119fb73">3bf4f3ea45f0022b6cd36415f095f1bfc119fb73</a>
+<blockquote>
+<p>
+ pdfwrite - improve further the glyph bounding box calculation<br>
+<br>
+ Bug #699571 &quot;Missing characters when convert eps to pdf. Ok when convert to png.&quot;<br>
+<br>
+ When deciding whether to include a text string in the output PDF file<br>
+ we compare the bounding box of the string with the bounding box of the<br>
+ current clip path. If the string bbox is not at least partially within<br>
+ the clip, then we don't emit it.<br>
+<br>
+ To do this we previously used the font's FontBBox in order to estimate<br>
+ the size of each glyph in the string.<br>
+<br>
+ Commit 6a4202691c4317a698fa23c5309ad8974fe2b003 fixed a bug where the<br>
+ font has a wildly incorrect FontBBox leading to us deciding that the<br>
+ glyph was outside the clip area.<br>
+<br>
+ In that commit Chris Liddell noted that using the 'real' glyph bounding<br>
+ box would require executing the complete CharString which has<br>
+ performance implications.<br>
+<br>
+ Unfortunately this latest bug has forced us into this course. The EPS<br>
+ file draws the same glyph multiple times, clipping portions of it each<br>
+ time. Sometimes it uses charpath/fill to render the clipped portion, and<br>
+ sometimes it uses an xyshow where the advance in both directions is 0.<br>
+ At the same time, the font has a completely inaccurate FontBBox.<br>
+<br>
+ Because the advance width is 0 the previous fix does not address this<br>
+ situation. The FontBBox is so inaccurate that most of the times the<br>
+ glyph is rendered it is deemed to be outside the clip.<br>
+<br>
+ The only remaining solution is to determine the *actual* Bounding Box<br>
+ of the glyph, which means we have to execute the glyph description.<br>
+<br>
+ This does result in some degradation in performance.<br>
+<br>
+devices/vector/gdevpdte.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-08-03 10:40:44 +0100
+</strong>
+<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3cbfb32d83f8910a9aeae805542c805eba584e34">3cbfb32d83f8910a9aeae805542c805eba584e34</a>
+<blockquote>
+<p>
+ TrueType interpreter - set the TrueType rendering routine<br>
+<br>
+ Ensure the GS TTF interpreter is associated with a TTF font before attempting<br>
+ to retrieve the glyph bounding box. We have to eplicitly NULL the FAPI entry<br>
+ before doing so because, for normal rendering, we'll use the FAPI/Freetype API<br>
+ (in this case, we want to avoid rendering the glyph)<br>
+<br>
+ Fix supplied by Chris Liddell<br>
+<br>
+base/gstype42.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-05-26 19:11:58 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3f6507e834e92d9f5fc07ec8e91509a54ce9ec6d">3f6507e834e92d9f5fc07ec8e91509a54ce9ec6d</a>
+<blockquote>
+<p>
+ WIP: gitignore<br>
+<br>
+.gitignore<br>
+jbig2dec/.gitignore<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-08-03 19:14:15 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8c7d55b8f5b1248bf120ed312538bd824ba5ad9f">8c7d55b8f5b1248bf120ed312538bd824ba5ad9f</a>
+<blockquote>
+<p>
+ jbig2dec: Avoid accessing symbol bitmap width if it is missing.<br>
+<br>
+jbig2dec/jbig2_text.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-08-03 19:11:02 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=06d82c1d8b0c625f5bb8db8acd7113ff0b8179d8">06d82c1d8b0c625f5bb8db8acd7113ff0b8179d8</a>
+<blockquote>
+<p>
+ jbig2dec: Prevent underflow when checking if enough data for bitmap.<br>
+<br>
+ When decoding the symbol dictionary the bitmap size field<br>
+ determines the size of the bitmap. The bitmap size is however<br>
+ restricted to the size of the segment's data region. This was<br>
+ checked previously, but the check itself may underflow, so<br>
+ another check was introduced to prevent this from happening.<br>
+<br>
+jbig2dec/jbig2_symbol_dict.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-08-03 19:10:09 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d20a98cb7d3e10a68c7d288318f216db70db610c">d20a98cb7d3e10a68c7d288318f216db70db610c</a>
+<blockquote>
+<p>
+ jbig2dec: When reading past the end of a word stream, return 0.<br>
+<br>
+ Previously the returned value would be uninitialized, leading<br>
+ to issues detected by valgrind later on in the parsing.<br>
+<br>
+jbig2dec/jbig2.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-08-03 12:28:23 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=105f72c232121b12ec2b53bc76c66dd8cf821a78">105f72c232121b12ec2b53bc76c66dd8cf821a78</a>
+<blockquote>
+<p>
+ jbig2dec: Initialize entire page structure upon allocation.<br>
+<br>
+ Without this uninitialized values in the page structure will be<br>
+ used when parsing segments. An example of this is in<br>
+ jbig2_immediate_generic_region() when a the height of the page is<br>
+ used to determine if the region is outside of the page.<br>
+<br>
+jbig2dec/jbig2.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-04-26 01:48:05 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=163d0687c8c6bcfbff9e2ebae634530de0c3ebce">163d0687c8c6bcfbff9e2ebae634530de0c3ebce</a>
+<blockquote>
+<p>
+ jbig2dec: Explanation of (un)optimized generic region decoder.<br>
+<br>
+ Previously it was difficult to understand the magic values used in the<br>
+ optimized generic region decoder, and also whether the order of pixels<br>
+ in the context in the unoptimized decoder were important. This new<br>
+ explanation attempts to rectify these issues.<br>
+<br>
+jbig2dec/jbig2_generic.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-07-24 01:00:18 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e115b9b367645f85b42c5c7922b84af6fad7a907">e115b9b367645f85b42c5c7922b84af6fad7a907</a>
+<blockquote>
+<p>
+ jbig2dec: Print warning messages even for non-debug builds.<br>
+<br>
+ This is useful because jbig2dec emits warnings when it encounters<br>
+ broken files it is able to cope with, e.g. referrals to symbols<br>
+ outside the symbol dictionary are ignored but a warning is<br>
+ emitted. Ghostscript ought to output warnings in these cases so<br>
+ that users know that the final render might not be the intended<br>
+ one because the input file is broken.<br>
+<br>
+base/sjbig2.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-07-01 17:26:21 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2db336dc75bf710bcf327545c61f2d215332ce99">2db336dc75bf710bcf327545c61f2d215332ce99</a>
+<blockquote>
+<p>
+ jbig2dec: Read region segment height/width/x/y as unsigned.<br>
+<br>
+ The specification in 5.4.4 states that numbers are unsigned unless<br>
+ otherwise stated. 7.4.1.1 through 7.4.1.4 specifying the region segment<br>
+ height, width, x and y do not mention that these fields are signed,<br>
+ hence they ought to read and handled as unsigned.<br>
+<br>
+jbig2dec/jbig2_generic.c<br>
+jbig2dec/jbig2_halftone.c<br>
+jbig2dec/jbig2_page.c<br>
+jbig2dec/jbig2_page.h<br>
+jbig2dec/jbig2_refinement.c<br>
+jbig2dec/jbig2_segment.c<br>
+jbig2dec/jbig2_segment.h<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-07-08 14:10:09 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fd551bc0e40d2220b4343aeeefa7d9d3a64140eb">fd551bc0e40d2220b4343aeeefa7d9d3a64140eb</a>
+<blockquote>
+<p>
+ jbig2dec: Use accurate references to the specification.<br>
+<br>
+jbig2dec/jbig2_halftone.c<br>
+jbig2dec/jbig2_halftone.h<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-07-31 19:32:00 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ab862e07f1a804d5cf55548e73c0128673070e17">ab862e07f1a804d5cf55548e73c0128673070e17</a>
+<blockquote>
+<p>
+ jbig2dec: Support up to 16 bit gray-scale image for halftoning.<br>
+<br>
+ Without this commit if jbig2dec is fed a fuzzed bitstream where<br>
+ HBPP ends up larger than 8, jbig2dec will access bits outside of<br>
+ each 8 bit sample in GSVALS.<br>
+<br>
+ HBPP is in Table 22 in 6.6.4 defined to be 32 bits unsigned. The<br>
+ specification in C.2 limits GSBPP to 6 bits unsigned, a maximum<br>
+ value of 63, i.e. a gray-scale image with 63 bits per sample.<br>
+ According to table 23 in 6.6.5 HBPP is assigned to GSBPP, so any<br>
+ value larger than 63 would be out of spec.<br>
+<br>
+ A non-fuzzed bitstream that has HBPP larger than 9 is yet to be<br>
+ encountered. So for the time being use uint16_t the GSVALS and<br>
+ limit HBPP to 16. If a file with HBPP larger than 16 is ever<br>
+ encountered, the type and limit needs to be revisited.<br>
+<br>
+jbig2dec/jbig2_halftone.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-07-09 00:42:51 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=907b9dff401154cdf5a4716e4f067bdf3a45de27">907b9dff401154cdf5a4716e4f067bdf3a45de27</a>
+<blockquote>
+<p>
+ jbig2dec: Use corresponding stride for gray-scale bitplane.<br>
+<br>
+ All bitplanes have the same stride, but this change makes it obvious<br>
+ that we will not overwrite any boundaries (i.e. use the stride of the<br>
+ bitplane in question, not the stride for another bitplane).<br>
+<br>
+jbig2dec/jbig2_halftone.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-07-08 22:05:57 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7f4cd0ad4c0d8636141de50bb6eb76b17e574eb5">7f4cd0ad4c0d8636141de50bb6eb76b17e574eb5</a>
+<blockquote>
+<p>
+ jbig2dec: Fix accidental typo in context size function.<br>
+<br>
+jbig2dec/jbig2_generic.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-07-04 03:03:17 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2bc62e131fb14d22e7f4e0701a190b1cf50e9792">2bc62e131fb14d22e7f4e0701a190b1cf50e9792</a>
+<blockquote>
+<p>
+ jbig2dec: Ignore negative pixel runs in MMR decoder.<br>
+<br>
+ Previously these were fatal errors, now warn and continue.<br>
+<br>
+jbig2dec/jbig2_mmr.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-07-03 00:36:40 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9bff24e265f40fca19926f2a44390d1ac543e309">9bff24e265f40fca19926f2a44390d1ac543e309</a>
+<blockquote>
+<p>
+ jbig2dec: Ignore missing glyphs when rendering text region.<br>
+<br>
+jbig2dec/jbig2_text.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-05-28 22:46:16 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=052910bb5f16adaa0bc28fb2e8c7aeb562e0e7cb">052910bb5f16adaa0bc28fb2e8c7aeb562e0e7cb</a>
+<blockquote>
+<p>
+ jbig2dec: Rephrase jbig2_error() messages.<br>
+<br>
+ * Do not prefix messages with &quot;jbig2 error:&quot;, this ought to be<br>
+ done by the error callback itself.<br>
+ * Avoid using function names in messages as they mean nothing to<br>
+ the end user.<br>
+ * Avoid contractions in messages.<br>
+ * Try to adhere to &quot;failed to&quot; pattern as far as possible.<br>
+ * Messages start with lower case character, unless it refers to<br>
+ something in the specification.<br>
+ * Messages do not end with punctuation.<br>
+<br>
+jbig2dec/jbig2.c<br>
+jbig2dec/jbig2_arith.c<br>
+jbig2dec/jbig2_arith_iaid.c<br>
+jbig2dec/jbig2_arith_int.c<br>
+jbig2dec/jbig2_generic.c<br>
+jbig2dec/jbig2_halftone.c<br>
+jbig2dec/jbig2_huffman.c<br>
+jbig2dec/jbig2_image.c<br>
+jbig2dec/jbig2_image_pbm.c<br>
+jbig2dec/jbig2_page.c<br>
+jbig2dec/jbig2_refinement.c<br>
+jbig2dec/jbig2_segment.c<br>
+jbig2dec/jbig2_symbol_dict.c<br>
+jbig2dec/jbig2_text.c<br>
+jbig2dec/jbig2dec.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-07-03 20:02:04 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fdf6a2d9b8a33b04429608c104680d982fb085f5">fdf6a2d9b8a33b04429608c104680d982fb085f5</a>
+<blockquote>
+<p>
+ jbig2dec: Implement support for generic region pixel skipping.<br>
+<br>
+jbig2dec/jbig2_generic.c<br>
+jbig2dec/jbig2_generic.h<br>
+jbig2dec/jbig2_halftone.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-07-04 12:36:41 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c10cd780ace02cdc2a07e9c9e59e4617c0434fc6">c10cd780ace02cdc2a07e9c9e59e4617c0434fc6</a>
+<blockquote>
+<p>
+ jbig2dec: Fix where end row of stripe was only updated locally.<br>
+<br>
+jbig2dec/jbig2_page.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-07-03 03:10:55 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=90964e633488e2d8e9fa450ebe04ace16ec0d396">90964e633488e2d8e9fa450ebe04ace16ec0d396</a>
+<blockquote>
+<p>
+ jbig2dec: Warn on too many symbols in text region, do not report fatal error.<br>
+<br>
+ This condition is already taken care of by not continuing to read symbols,<br>
+ so attempt to proceed with parsing the image.<br>
+<br>
+jbig2dec/jbig2_text.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-07-02 12:44:31 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0073f2a6524c731528e950deb7eac598c819a3da">0073f2a6524c731528e950deb7eac598c819a3da</a>
+<blockquote>
+<p>
+ jbig2dec: Treat unstriped pages with unknown height as striped with max stripe height.<br>
+<br>
+jbig2dec/jbig2_page.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-07-01 17:25:48 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3d8b1c3fc85271e075b22627182998ae4cf894d5">3d8b1c3fc85271e075b22627182998ae4cf894d5</a>
+<blockquote>
+<p>
+ jbig2dec: Limit region height to page/stripe height.<br>
+<br>
+ Make sure to ignore regions outside of stripe/page.<br>
+<br>
+jbig2dec/jbig2_generic.c<br>
+jbig2dec/jbig2_page.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-07-09 01:30:11 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f3e4a8978b9577bad31d0f818b206eb65da222d6">f3e4a8978b9577bad31d0f818b206eb65da222d6</a>
+<blockquote>
+<p>
+ jbig2dec: Stripe offsets are absolute, not relative.<br>
+<br>
+jbig2dec/jbig2_page.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-07-30 16:24:28 +0100
+</strong>
+<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cf964a720496ff8e1c55f0d629bdec91b789faf0">cf964a720496ff8e1c55f0d629bdec91b789faf0</a>
+<blockquote>
+<p>
+ Coverity ID 305953 - uninitialised variable<br>
+<br>
+ Also a scan-build warning.<br>
+<br>
+devices/vector/gdevpdtt.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-07-01 00:36:28 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e3212ede0590b02ef57f8946ae413ce44ef3658e">e3212ede0590b02ef57f8946ae413ce44ef3658e</a>
+<blockquote>
+<p>
+ jbig2dec: Cap runlength for exported symbols, don't error out.<br>
+<br>
+ Capping is necessary because the preceding symbol dictionary segment header<br>
+ stated that a specific number of symbols will be exported to succeeding symbol<br>
+ dictionaries. By capping overly long runlengths of exported symbol instead of<br>
+ reporting fatal errors somewhat corrupt JBIG2 bitstreams may still partially<br>
+ render, albeit with a warning about the capping taking place.<br>
+<br>
+jbig2dec/jbig2_symbol_dict.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-07-01 13:28:26 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=bbbb7eff0b63f383e073ec760b2b8a94896d81a1">bbbb7eff0b63f383e073ec760b2b8a94896d81a1</a>
+<blockquote>
+<p>
+ jbig2dec: Occasional runlengths may be zero, avoid infinite sequence.<br>
+<br>
+ Previously any runlength when exporting symbol dictionary symbols<br>
+ being zero caused a fatal error. These are not disallowed by the<br>
+ specification, but if there is an infinite sequence of them the<br>
+ decoder cannot make any progress in establishing the dictionary<br>
+ of exported symbols from a symbol dictionary. This may happen<br>
+ when the huffman or arithmetic integer decoder due to e.g. fuzzed<br>
+ input data returns an infinite sequence of zeroes when the<br>
+ decoder attempts to read the runlengths. This case of infinite<br>
+ zero runlengths is best handled as a fatal error. An arbitrary<br>
+ limit of 1000 of zero runlengths in sequence (an approximation of<br>
+ an infinite sequence of zero runlengths) will now cause a fatal<br>
+ error, but the occasional zero runlength will be accepted without<br>
+ any kind of message.<br>
+<br>
+jbig2dec/jbig2_symbol_dict.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-07-13 14:10:40 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=55ed0cbe04df585a987ca8ce7b6255e9705646d1">55ed0cbe04df585a987ca8ce7b6255e9705646d1</a>
+<blockquote>
+<p>
+ jbig2dec: Advance and limit b1 in MMR decoder in a single location.<br>
+<br>
+ Previously this unnecessarily happened multiple times.<br>
+<br>
+jbig2dec/jbig2_mmr.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-07-13 13:39:42 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1d22aa82619bfd6e02dd1e4afa019a68ba2f3cca">1d22aa82619bfd6e02dd1e4afa019a68ba2f3cca</a>
+<blockquote>
+<p>
+ jbig2dec: Remove check for a0 set before scanline in MMR decoder.<br>
+<br>
+ A few lines of code prior if a0 is set before the scanline it is<br>
+ reset to index 0, so no need to recheck for this condition.<br>
+<br>
+jbig2dec/jbig2_mmr.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-07-13 13:00:06 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=230dd860b0db9924794570654db3bb162194977e">230dd860b0db9924794570654db3bb162194977e</a>
+<blockquote>
+<p>
+ jbig2dec: Error message in MMR coded data mixed black/white pixel runs.<br>
+<br>
+jbig2dec/jbig2_mmr.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-07-13 12:31:19 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7f94da2ccf574524d71a7d6aa2e381893dbacb37">7f94da2ccf574524d71a7d6aa2e381893dbacb37</a>
+<blockquote>
+<p>
+ jbig2dec: The MMR runlength tables list error codes, handle those.<br>
+<br>
+ Previously these errors led to spurious negative values for runlengths,<br>
+ which were treated as if these were legal even though they are not.<br>
+<br>
+jbig2dec/jbig2_mmr.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-07-26 11:43:10 +0100
+</strong>
+<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4b16b3762c1177497633178303665317eae8297e">4b16b3762c1177497633178303665317eae8297e</a>
+<blockquote>
+<p>
+ Bug 699560: Shut down libjpeg encoder in gdevjpeg<br>
+<br>
+ Have the jpeg devices correctly shutdown libjpeg and release the encoder<br>
+ context correctly - solves memory leaks reported by memento.<br>
+<br>
+devices/gdevjpeg.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-07-26 08:28:23 +0100
+</strong>
+<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2f017502459778cac3c2b8cb2c6df2f52629aae3">2f017502459778cac3c2b8cb2c6df2f52629aae3</a>
+<blockquote>
+<p>
+ pdfwrite - don't retry CharProc capture on error.<br>
+<br>
+ Bug #699561 &quot;Infinite loop or Segfault&quot;<br>
+<br>
+ The input PostScript file for this case is invalid and throws a<br>
+ rangecheck error with normal devices.<br>
+<br>
+ However when the output device is pdfwrite in the case of *any* error<br>
+ handling text we fall back to the 'default implementation' which means<br>
+ we run the glyph description normally, and capture the bitmap into a<br>
+ type 3 bitmap font.<br>
+<br>
+ In the case of this file, however, when we try to use the captured<br>
+ bitmap we again throw an error. This causes us to run the glyph<br>
+ description again and capture the bitmap. Of course, that again fails<br>
+ when we try to use it leading to an infinite loop. But not any simple<br>
+ loop, it involves exiting the code and re-entering it after capture.<br>
+<br>
+ This commit adds a new variable, captured_pte_index. When we complete<br>
+ a capture, we record the index (the pointer to the input character codes)<br>
+ from the text enumerator. We then try to process the text as normal. If<br>
+ we get an error, before falling back to the default implementation, we<br>
+ test the current text enumerator index. If its the same as the captured<br>
+ index then we know that it was the captured CharProc threw an error.<br>
+<br>
+ In the case of this kind of error we simply return the error, there is<br>
+ nothing further we can do.<br>
+<br>
+devices/vector/gdevpdtt.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-07-20 11:43:54 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d735b5ae0b8fc6573f09aee9b8663612bdde3c9b">d735b5ae0b8fc6573f09aee9b8663612bdde3c9b</a>
+<blockquote>
+<p>
+ jbig2dec: Change overflow check for allocations.<br>
+<br>
+ The maximum size of an allocation was previously limited to<br>
+ (maximum value of size_t)-256 bytes. Use SIZE_MAX instead.<br>
+<br>
+jbig2dec/jbig2.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-06-29 17:47:25 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2272769bf1126e20f8458729c334f2134b95e951">2272769bf1126e20f8458729c334f2134b95e951</a>
+<blockquote>
+<p>
+ jbig2dec: Always complete a page, attempting decode of problematic streams.<br>
+<br>
+ When JBIG2 bitstreams contain end of page segments the parser in<br>
+ jbig2dec calls jbig2_complete_page() to signal that the page is<br>
+ now finished.<br>
+<br>
+ JBIG2 bitstreams created by some producers do not contain end of<br>
+ page segments but are otherwise well-formed JBIG2 bitstreams.<br>
+ Embedded JBIG2 bitstreams do not have to contain end of page<br>
+ segments. jbig2dec previously tried to detect these cases and<br>
+ simulated an end of page segment by manually calling<br>
+ jbig2_complete_page() so as to be able to output a displayable<br>
+ image.<br>
+<br>
+ Problematic non-embedded JBIG2 bitstreams that have parse errors<br>
+ before any end of page segment is reached, or bitstreams where<br>
+ the end of page segment itself is broken, do not fall into either<br>
+ of the categories above but may be missing end of page segments.<br>
+ Previously jbig2dec treated this type of bistreams as not having<br>
+ any displayable image because the pages were never finished.<br>
+<br>
+ To handle all types of bitstreams and attempt to output a<br>
+ displayable image (possibly partial due to parse errors),<br>
+ jbig2dec now always calls jbig2_complete_page() function.<br>
+<br>
+jbig2dec/jbig2dec.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-07-13 12:49:36 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2483cf3a3467068510a012dc814aa607d6c6a32f">2483cf3a3467068510a012dc814aa607d6c6a32f</a>
+<blockquote>
+<p>
+ jbig2dec: Limit scanline index in MMR coded data.<br>
+<br>
+ According to the T.6 specification the pixel references, e.g. a0,<br>
+ may point to any of the pixels (indices 0 through N-1) on a<br>
+ scanline, one pixel to the left of a scanline (index MINUS1) or<br>
+ one pixel beyond the scanline (index N). These indicies are all<br>
+ positive (despite its name MINUS1 is defined to UINT32_MAX).<br>
+<br>
+ This commit changes the index type from signed to unsigned to<br>
+ reflect this. Moreover, when looking for changing elements,<br>
+ make sure to limit the returned index to N.<br>
+<br>
+jbig2dec/jbig2_mmr.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-07-13 12:41:14 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e05019b96b7e038d9335e640b83db098022d1e2c">e05019b96b7e038d9335e640b83db098022d1e2c</a>
+<blockquote>
+<p>
+ jbig2dec: Handle EOFB whether it is required or not.<br>
+<br>
+ Chapter 6.2.6 in the JBIG2 specification states that MMR-encoded<br>
+ data _may_ skip the EOFB code when the data length is known in<br>
+ advance. If the data length is _not_ known in advance EOFB is<br>
+ required. Since an encoder may choose to use or skip EOFB when<br>
+ the data length is known, decoders must always be prepared to<br>
+ handle EOFB regardless of whether the data length is known or<br>
+ unknown.<br>
+<br>
+ After encountering EOFB jbig2dec now stops consuming MMR-coded<br>
+ data regardless of whether the data lenght is known in advance<br>
+ or not. The remainder of the decoded image region is filled with<br>
+ white.<br>
+<br>
+jbig2dec/jbig2_mmr.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-05-29 03:09:58 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7fade522e9e406b1faedc76e71f86951901633d2">7fade522e9e406b1faedc76e71f86951901633d2</a>
+<blockquote>
+<p>
+ jbig2dec: Limit image size to 2GByte and check for overflow.<br>
+<br>
+ The width/height fields of a JBIG2 image are limited by the<br>
+ specification to UINT32_MAX. This means that the total size of<br>
+ the image is limited to UINT32_MAX * UINT32_MAX pixels.<br>
+<br>
+ jbig2_alloc() take a size argument of type size_t, limiting<br>
+ allocations to at most SIZE_MAX bytes. For 32 bit systems<br>
+ SIZE_MAX == UINT32_MAX and for 64 bit systems SIZE_MAX ==<br>
+ UINT64_MAX.<br>
+<br>
+ This means that for 32 bit systems the maximum image size is<br>
+ limited to UINT32_MAX * 8 pixels. For 64 bit systems it could<br>
+ conceivably be limited to UINT64_MAX * 8 pixels if all indexing<br>
+ into the image buffer allocation is 64 bit safe.<br>
+<br>
+ However jbig2dec's indexing into the image buffer allocations is<br>
+ not always 64 bit safe, so limit image allocations to the safe<br>
+ choice of 2Gbyte. This equates to limiting image sizes to<br>
+ INT32_MAX * 8 pixels, or a square of 131072 by 131072 pixels.<br>
+<br>
+jbig2dec/jbig2_image.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-06-20 01:38:41 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6f06c79a4f0ee664840ce7bedc35dafc921e5086">6f06c79a4f0ee664840ce7bedc35dafc921e5086</a>
+<blockquote>
+<p>
+ jbig2dec: Cast BMSIZE in symbol dicts to size_t.<br>
+<br>
+ BMSIZE is used to skip over uncompressed symbols in a symbol dictionary.<br>
+ Therefore this value is inherently unsigned. Also because the value is<br>
+ a multiplication of the height and stride of an image, both of which are<br>
+ unsigned 32 bit numbers, rely on the size_t type which is large enough<br>
+ to handle images this big.<br>
+<br>
+jbig2dec/jbig2_huffman.c<br>
+jbig2dec/jbig2_huffman.h<br>
+jbig2dec/jbig2_symbol_dict.c<br>
+jbig2dec/jbig2_text.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-05-29 02:58:14 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c01e08cf984192defb63017e1a11a9f1bf05f9ef">c01e08cf984192defb63017e1a11a9f1bf05f9ef</a>
+<blockquote>
+<p>
+ jbig2dec: Remove denial of service check which is no longer needed.<br>
+<br>
+ In commit ee0bc20cc98c8e8381003a25dfa0b21e681c6545 an attempt to detect the end<br>
+ of the arithmetic integer decoder bit stream is detected. Now once more error<br>
+ handling has been implemented, the files from bug 694949 that caused this end of<br>
+ bitstream detection code to be added no longer end in an infinite loop, but fail<br>
+ with fatal errors due to other reasons.<br>
+<br>
+jbig2dec/jbig2_arith.c<br>
+jbig2dec/jbig2_symbol_dict.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-07-24 13:35:03 +0100
+</strong>
+<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=160431b50a3154341fa9ef1270ecb6f8ae045b4d">160431b50a3154341fa9ef1270ecb6f8ae045b4d</a>
+<blockquote>
+<p>
+ Fix tiffpack and tifflzw devices<br>
+<br>
+ Commit 0ef309305417776a9f8b8cd143fbf3c5e89456b2 moved the FillOrder<br>
+ parameter into the 'generic' tiff fax device structure, and added a new<br>
+ BlackIs1 parameter.<br>
+<br>
+ The macro FAX_DEVICE_BODY was updated to reflect this but unfortunately<br>
+ two of the devices, tiffpack and tifflzw do not use the FAX_DEVICE_BODY<br>
+ macro, as they need to use device-specific code for the output_page<br>
+ device method.<br>
+<br>
+ This meant that the initialisation of these devices was incorrect and<br>
+ led to failures in our automated testing.<br>
+<br>
+devices/gdevtfax.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-07-23 11:54:50 +0100
+</strong>
+<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=da7288fe212f24db7789f9807b9e55a0e4367b8a">da7288fe212f24db7789f9807b9e55a0e4367b8a</a>
+<blockquote>
+<p>
+ gx_cpath_unshare(): zero unset entries.<br>
+<br>
+ gx_cpath_unshare() does not copy the clip path list, and leaves the list<br>
+ structure uninitialized.<br>
+<br>
+ Until/Unless we implement copying the list, set the values in the list to<br>
+ zero/NULL so later freeing of the unshared clip path doesn't trip up.<br>
+<br>
+base/gxcpath.c<br>
+base/lib.mak<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-07-18 16:41:17 +0100
+</strong>
+<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=954d535ee5a63ff751c1af24bbd45adefc2a078c">954d535ee5a63ff751c1af24bbd45adefc2a078c</a>
+<blockquote>
+<p>
+ Bug 699542: Fix compiler/linker options for shared lib on AIX<br>
+<br>
+configure.ac<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-07-18 16:32:38 +0100
+</strong>
+<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3afe2983e8e3c5fd9f290d7af0f7469d944a57ec">3afe2983e8e3c5fd9f290d7af0f7469d944a57ec</a>
+<blockquote>
+<p>
+ Bug 699543: handle missing isinf() and fpclassify()<br>
+<br>
+Makefile.in<br>
+base/lcms2mt.mak<br>
+configure.ac<br>
+lcms2mt/src/cmsplugin.c<br>
+lcms2mt/src/lcms2_internal.h<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-07-24 13:03:39 +0100
+</strong>
+<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f6bcc0dfc173b80fddab4fbf10afb34332ff1112">f6bcc0dfc173b80fddab4fbf10afb34332ff1112</a>
+<blockquote>
+<p>
+ PDF interpreter - improve handling of 'q' inside a text object<br>
+<br>
+ Bug #699551 &quot;Text with rendering mode stroke is not displayed&quot;<br>
+<br>
+ We already did deal with a q/Q pair inside a text object (BT/ET pair)<br>
+ but a couple of points were missed. We didn't check for the existence<br>
+ of a qTextSavematrix in settextstate, which meant that we didn't<br>
+ set the text matrix. So vector and image marking worked, but text did<br>
+ not.<br>
+<br>
+ We also didn't check for the existence of a qSaveTextMatrix when handling<br>
+ the stroke width for a text rendering mode which involves stroking the<br>
+ text.<br>
+<br>
+ This commit exhibits one 'progression' (ie it now matches Acrobat) in<br>
+ the Quality Logice PDF 2.0 FTS files. I intend to raise this with QL as<br>
+ the file is demonstrably invalid.<br>
+<br>
+ It also adversely impacts the performance of text in PDF files, since we<br>
+ must now do additional checking on every text operation. This has pushed<br>
+ a small number of our test files beyond the point where they start to<br>
+ time out on our automated testing.<br>
+<br>
+Resource/Init/pdf_ops.ps<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-07-23 13:50:59 -0600
+</strong>
+<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0ef309305417776a9f8b8cd143fbf3c5e89456b2">0ef309305417776a9f8b8cd143fbf3c5e89456b2</a>
+<blockquote>
+<p>
+ Bug 699425, new fax device parameters added.<br>
+<br>
+ Two new device parameters specify bit order and black white polarity,<br>
+ these parameters are the same as found in the tiff fax devices<br>
+ (gdevtfax.c)<br>
+<br>
+devices/gdevfax.c<br>
+devices/gdevfax.h<br>
+devices/gdevtfax.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-07-23 11:51:03 -0600
+</strong>
+<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=dca564fc2a95b6610084ad06a939367217aa78e3">dca564fc2a95b6610084ad06a939367217aa78e3</a>
+<blockquote>
+<p>
+ Bug #699550 - Fix infinite loop processing PCL file with JPEG image.<br>
+<br>
+ The color depth was set to 1 instead of 8 resulting in an ouput buffer<br>
+ smaller than the filter needed. Also, make sure we process the return<br>
+ code from the dct stream filter correctly so an error will be handled<br>
+ properly.<br>
+<br>
+pcl/pxl/pximage.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-07-20 10:46:59 +0100
+</strong>
+<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=285cd8f8ced5b561116190d56e14baabef740ee9">285cd8f8ced5b561116190d56e14baabef740ee9</a>
+<blockquote>
+<p>
+ ps2write - add a check for PreserveSeparation<br>
+<br>
+ When we check for a /Separation with a Lab alternate, check whether we<br>
+ should be preserving Separation spaces before going ahead and converting<br>
+ the alternate space to the ProcessColorModel of the device.<br>
+<br>
+devices/vector/gdevpdfg.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-07-20 10:45:33 +0100
+</strong>
+<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d0c058c8ef9112f6245e96e3cef81a24e7c9c103">d0c058c8ef9112f6245e96e3cef81a24e7c9c103</a>
+<blockquote>
+<p>
+ Documentation - Documentation on PreserveSeparation for pdfwrite was missing<br>
+<br>
+doc/VectorDevices.htm<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-07-20 09:49:44 +0100
+</strong>
+<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9e58cc8dd7e9b98620c798c901f800aff2e381ce">9e58cc8dd7e9b98620c798c901f800aff2e381ce</a>
+<blockquote>
+<p>
+ ps2write - improve handling of Separation colour space with Lab alternate<br>
+<br>
+ Bug #699535 &quot;Separation Colors with alternate Color Lab are not converted correctly when device (e)ps2write is used&quot;<br>
+<br>
+ We can't embed a Lab space in the output from ps2write with the current<br>
+ colour handling. So instead spot the condition and convert the<br>
+ /Separation alternate space into the underlying ProcessColorModel.<br>
+<br>
+ This preserves the /Separation ink, though the resulting tint transform<br>
+ is less than ideal.<br>
+<br>
+ At the same time, make sure we don't try to handle the ICC Lab space<br>
+ as if it were a device space. Instead return a rangecheck error so that<br>
+ we convert the whole space into the ProcessColorModel.<br>
+<br>
+devices/vector/gdevpdfc.c<br>
+devices/vector/gdevpdfg.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-07-19 12:09:02 +0100
+</strong>
+<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b44096b33d28d25c8f88c9fc2565713d85ca0614">b44096b33d28d25c8f88c9fc2565713d85ca0614</a>
+<blockquote>
+<p>
+ JBIG2DEC - add declarations which are not defined in VS 2005<br>
+<br>
+ Like INT32_MAX and INT32_MIN, UINT32_MAX which is defined in stdint.h<br>
+ is not defined for old versions of Visual Studio. Add simple definitions<br>
+ in the two source files that use it, if it is not already defined.<br>
+<br>
+jbig2dec/jbig2_generic.c<br>
+jbig2dec/jbig2_segment.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-07-01 17:26:37 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e7ededef7c8b09845aedae08674519fbf50654b8">e7ededef7c8b09845aedae08674519fbf50654b8</a>
+<blockquote>
+<p>
+ jbig2dec: Ignore extension segments that are not marked necessary.<br>
+<br>
+ Previously this was a fatal error, but it is better as a warning as<br>
+ the extension segment has not been marked necessary as outlined in<br>
+ the specification.<br>
+<br>
+jbig2dec/jbig2_segment.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-07-04 22:23:26 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a6fef0ad778e67783204f71a28119a47fe6eb7c7">a6fef0ad778e67783204f71a28119a47fe6eb7c7</a>
+<blockquote>
+<p>
+ jbig2dec: Improve halftoning debug message.<br>
+<br>
+jbig2dec/jbig2_halftone.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-07-11 02:40:57 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c21d7dfb8cd82f698eb93b0b122a4e01c152faad">c21d7dfb8cd82f698eb93b0b122a4e01c152faad</a>
+<blockquote>
+<p>
+ jbig2dec: Fix composing subset of image onto destination.<br>
+<br>
+jbig2dec/jbig2_image.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-07-01 13:19:43 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f8300fe31d487088e2de195ab0bf3a5725e6806f">f8300fe31d487088e2de195ab0bf3a5725e6806f</a>
+<blockquote>
+<p>
+ jbig2dec: Warn on out of range symbol IDs, but continue.<br>
+<br>
+jbig2dec/jbig2_text.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-07-01 13:18:48 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=12e9787cd20407b1440edf212d8e7f1c544dc29e">12e9787cd20407b1440edf212d8e7f1c544dc29e</a>
+<blockquote>
+<p>
+ jbig2dec: Use already parsed size of page association field.<br>
+<br>
+jbig2dec/jbig2_segment.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-07-01 13:03:01 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=72165c941ad4c4134ca593cd744be6b1b5ac1dda">72165c941ad4c4134ca593cd744be6b1b5ac1dda</a>
+<blockquote>
+<p>
+ jbig2dec: Handle text regions without symbol dictionaries.<br>
+<br>
+ Normal text regions reference symbol dictionaries. The symbols<br>
+ in those dictionaries are then referenced to by the text region<br>
+ and placed somewhere on the page. In the degenerate case a text<br>
+ region might not have any instances of symbols that it wants to<br>
+ place on the page. If that is the case then there is no need for<br>
+ the text region to refer to any symbol dictionaries (since it<br>
+ doesn't need any symbols). Previously this was treated as a fatal<br>
+ error, but now this just creates a warning and decoding proceeds.<br>
+<br>
+jbig2dec/jbig2_text.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-07-01 13:07:19 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=de25a4676d82587b8c6d6c6aeca3785514fde1c2">de25a4676d82587b8c6d6c6aeca3785514fde1c2</a>
+<blockquote>
+<p>
+ jbig2dec: Attempting to compose NULL on a page is silently accepted.<br>
+<br>
+jbig2dec/jbig2_image.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-07-04 22:19:34 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b417ef1deee793f93cc0643e3eccc4a8fea6cf3d">b417ef1deee793f93cc0643e3eccc4a8fea6cf3d</a>
+<blockquote>
+<p>
+ jbig2dec: Make local functions static.<br>
+<br>
+jbig2dec/jbig2_halftone.c<br>
+jbig2dec/jbig2_halftone.h<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-06-29 01:54:15 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5158b558038c939c287d3a1194412134a5dc1134">5158b558038c939c287d3a1194412134a5dc1134</a>
+<blockquote>
+<p>
+ jbig2dec: Handling missing OOB at end of height class.<br>
+<br>
+jbig2dec/jbig2_symbol_dict.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-06-24 16:00:30 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fb8347da8e388793a4add8442931dbd5033fce41">fb8347da8e388793a4add8442931dbd5033fce41</a>
+<blockquote>
+<p>
+ jbig2dec: Handle immediate generic regions with unknown height.<br>
+<br>
+jbig2dec/jbig2.c<br>
+jbig2dec/jbig2_generic.c<br>
+jbig2dec/jbig2_segment.c<br>
+jbig2dec/jbig2_segment.h<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-06-27 02:13:04 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=29371c6872f9b72e3810d76bd920f41619924fa7">29371c6872f9b72e3810d76bd920f41619924fa7</a>
+<blockquote>
+<p>
+ jbig2dec: Print segment number in messages when available.<br>
+<br>
+jbig2dec/jbig2.c<br>
+jbig2dec/jbig2_generic.c<br>
+jbig2dec/jbig2_mmr.c<br>
+jbig2dec/jbig2_refinement.c<br>
+jbig2dec/jbig2_segment.c<br>
+jbig2dec/jbig2_symbol_dict.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-06-22 21:16:24 +0800
+</strong>
+<br>Tor Andersson &lt;tor.andersson@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d469fa3d995c8593680c2425f9c2c5a7a231bac7">d469fa3d995c8593680c2425f9c2c5a7a231bac7</a>
+<blockquote>
+<p>
+ jbig2dec: Avoid accessing bytes outside of MMR decoder line.<br>
+<br>
+ Previously the file Bug688080.pdf in bug 693798 e.g. has an object 668<br>
+ containing a JBIG2 bitstream containing an MMR-coded region where the<br>
+ width of the region is 32 pixels. At one point while decoding this<br>
+ image, a0 is in the middle of the line and because of the decoded black<br>
+ and white runs both a1 and a2 end up at the pixel just beyond the end<br>
+ of the line. At this point jbig2dec would access the byte supposedly<br>
+ containing this pixel beyond the end of the line, but that is not<br>
+ allowed. Because this byte was written back unchanged no real harm was<br>
+ done, but the access was still being performed, triggering software<br>
+ like valgrind/ASAN that detects buffer overflows.<br>
+<br>
+ This commit also reverts the incorrect fix for bug 693798<br>
+ introduced in commit 46d6b40803cb7a68ceb06b2f71db8cf3f384c2ee<br>
+ where the allocated image buffer was simply extended by one byte,<br>
+ thereby accommodating the illegal access.<br>
+<br>
+jbig2dec/jbig2_image.c<br>
+jbig2dec/jbig2_mmr.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-07-14 18:19:47 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=dfa5b1b784b9c575cb9d797248e282871d24625c">dfa5b1b784b9c575cb9d797248e282871d24625c</a>
+<blockquote>
+<p>
+ jbig2dec: Untie fix for Visual Studio from Microsoft's compiler.<br>
+<br>
+ The i32 suffix is specific for MSVC, but can be avoided.<br>
+ gssprintf.c for APR_INT32_MAX and APR_INT32_MIN also leaves out<br>
+ the suffix out. This is legal because the default integer literal<br>
+ size is large enough to fit 32 bit signed integers.<br>
+<br>
+jbig2dec/jbig2_arith_int.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-07-14 10:31:08 +0100
+</strong>
+<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=29363ac25e7f8796e4cd09a7a88b3b1104191519">29363ac25e7f8796e4cd09a7a88b3b1104191519</a>
+<blockquote>
+<p>
+ Jbig2dec - Fix compile error on old version of Visual Studio<br>
+<br>
+ A recent change uses INT32_MAX and INT32_MIN, but these are not defined<br>
+ in old versions of Visual Studio (not C99 probably).<br>
+<br>
+ This commit works around the problem by including two simple #defines<br>
+ if the values are undefined.<br>
+<br>
+ Sebastian may want to alter this.<br>
+<br>
+jbig2dec/jbig2_arith_int.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-06-10 16:36:21 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c7bd3bb9fc9d008ab9d70f4d762be95d3f33cb0c">c7bd3bb9fc9d008ab9d70f4d762be95d3f33cb0c</a>
+<blockquote>
+<p>
+ jbig2dec: Plug context leak upon errors.<br>
+<br>
+ E.g. failing to complete a page previously caused a context leak.<br>
+<br>
+jbig2dec/jbig2dec.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-06-10 21:29:31 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d06d19b3cfda9a563ffa09e4aa58322774d751fb">d06d19b3cfda9a563ffa09e4aa58322774d751fb</a>
+<blockquote>
+<p>
+ jbig2dec: Free huffman tables upon symbol dictionary parse errors.<br>
+<br>
+jbig2dec/jbig2_symbol_dict.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-06-10 21:14:48 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=afed61efb38bed3a5580ee0e458b8c6946ee49f5">afed61efb38bed3a5580ee0e458b8c6946ee49f5</a>
+<blockquote>
+<p>
+ jbig2dec: Free symbol images upon text region parse error.<br>
+<br>
+ The symbol images were previously not freed upon errors.<br>
+<br>
+jbig2dec/jbig2_text.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-06-19 23:16:17 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=314fb613ca8fa3028e33627bbb3fa484d4da1e13">314fb613ca8fa3028e33627bbb3fa484d4da1e13</a>
+<blockquote>
+<p>
+ jbig2dec: Remove untested, incomplete metadata handling.<br>
+<br>
+base/jbig2.mak<br>
+jbig2dec/Makefile.am<br>
+jbig2dec/Makefile.unix<br>
+jbig2dec/jbig2_metadata.c<br>
+jbig2dec/jbig2_metadata.h<br>
+jbig2dec/jbig2_segment.c<br>
+jbig2dec/msvc.mak<br>
+windows/ghostscript.vcproj<br>
+windows/ghostscript_rt.vcxproj<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-06-19 01:31:14 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3835fcfe6d3894e03a68c66bd211c7a739007b5d">3835fcfe6d3894e03a68c66bd211c7a739007b5d</a>
+<blockquote>
+<p>
+ jbig2dec: Limit EXRUNLENGTH according to symbol dictionary header.<br>
+<br>
+jbig2dec/jbig2_symbol_dict.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-06-19 01:30:34 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=22e702351066d38c30d2bf695140f8fe6719c3f3">22e702351066d38c30d2bf695140f8fe6719c3f3</a>
+<blockquote>
+<p>
+ jbig2dec: Remove unnecessary limitation of EXRUNLENGTH.<br>
+<br>
+ Due to missing boundary checks in other code bug 693285 was resolved<br>
+ by limiting the number of times EXRUNLENGTH may be zero. This limit<br>
+ is actually not according to the specification. Now that the missing<br>
+ boundary checks have been introduced the limitation may be removed.<br>
+<br>
+jbig2dec/jbig2_symbol_dict.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-06-18 19:04:38 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=be27bd6685b714e1deca80d580d3ff9dc82f78dc">be27bd6685b714e1deca80d580d3ff9dc82f78dc</a>
+<blockquote>
+<p>
+ jbig2dec: Make private function static.<br>
+<br>
+jbig2dec/jbig2_metadata.c<br>
+jbig2dec/jbig2_metadata.h<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-05-30 15:31:10 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=79eee7b35a6070cacfe94343d01e9e1b7ebb1191">79eee7b35a6070cacfe94343d01e9e1b7ebb1191</a>
+<blockquote>
+<p>
+ jbig2dec: Return NULL upon error, avoid returning variable.<br>
+<br>
+ This makes it clearer what is being returned upon error.<br>
+<br>
+jbig2dec/jbig2.c<br>
+jbig2dec/jbig2_arith.c<br>
+jbig2dec/jbig2_arith_iaid.c<br>
+jbig2dec/jbig2_arith_int.c<br>
+jbig2dec/jbig2_huffman.c<br>
+jbig2dec/jbig2_segment.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-06-01 14:33:11 -0700
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a97b724a6639e710cb4626ba53be2f86b1ebd5ba">a97b724a6639e710cb4626ba53be2f86b1ebd5ba</a>
+<blockquote>
+<p>
+ jbig2dec: Make sure to print fatal error upon detected error.<br>
+<br>
+jbig2dec/jbig2_huffman.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-06-01 16:56:39 -0700
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8ea06bef59929bbaa0450a94ab9586dd154657e8">8ea06bef59929bbaa0450a94ab9586dd154657e8</a>
+<blockquote>
+<p>
+ jbig2dec: Make sure to return fatal/warnings when propagating error.<br>
+<br>
+jbig2dec/jbig2_huffman.c<br>
+jbig2dec/jbig2_symbol_dict.c<br>
+jbig2dec/jbig2_text.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-05-30 17:30:37 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=443588c95d5776f141940d57aee2b3a0a21b668f">443588c95d5776f141940d57aee2b3a0a21b668f</a>
+<blockquote>
+<p>
+ jbig2dec: Change types to match those of the parsed data.<br>
+<br>
+jbig2dec/jbig2_generic.c<br>
+jbig2dec/jbig2_halftone.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-06-21 00:30:02 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0188d0818b6f5b25aefdbafefa46d2845a21da9b">0188d0818b6f5b25aefdbafefa46d2845a21da9b</a>
+<blockquote>
+<p>
+ jbig2dec: Keep track of previous lines in generic region decoding.<br>
+<br>
+ This avoids issues with negative array indices.<br>
+<br>
+jbig2dec/jbig2_generic.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-05-30 14:26:16 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7352f5a01fd2e0a1f221d25cbf35fe088226232e">7352f5a01fd2e0a1f221d25cbf35fe088226232e</a>
+<blockquote>
+<p>
+ jbig2dec: No need to check for NULL in huff_get_next_word, use macro instead.<br>
+<br>
+jbig2dec/jbig2_huffman.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-05-27 02:49:49 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6da6f365a8c93128fcd67938ed3f5ef362c77630">6da6f365a8c93128fcd67938ed3f5ef362c77630</a>
+<blockquote>
+<p>
+ jbig2dec: Label everything not yet implemented NYI.<br>
+<br>
+jbig2dec/jbig2_halftone.c<br>
+jbig2dec/jbig2_segment.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-05-27 02:48:56 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=67c937009233f4496b8ece8270c10c4021785752">67c937009233f4496b8ece8270c10c4021785752</a>
+<blockquote>
+<p>
+ jbig2dec: Validate ASCII characters in metadata comments.<br>
+<br>
+jbig2dec/jbig2_metadata.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-05-27 00:33:45 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5c8a10f2e936b990fa3340650849186e92f1ecfd">5c8a10f2e936b990fa3340650849186e92f1ecfd</a>
+<blockquote>
+<p>
+ jbig2dec: Implement support for profile segment.<br>
+<br>
+ The information in the profile segment is simply printed<br>
+ as informational messages via jbig2_error().<br>
+<br>
+jbig2dec/jbig2_segment.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-04-24 21:43:48 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=46f4acd48c81fa0db76f26c40b2e76c0fe7d7842">46f4acd48c81fa0db76f26c40b2e76c0fe7d7842</a>
+<blockquote>
+<p>
+ jbig2dec: Implement support for outputting multipage PBM files.<br>
+<br>
+jbig2dec/jbig2dec.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-04-25 02:47:39 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=540f6a2f1c7f98b29b60a6e666623caec8dc8983">540f6a2f1c7f98b29b60a6e666623caec8dc8983</a>
+<blockquote>
+<p>
+ jbig2dec: Share arithmetic/huffman decoding contexts/tables.<br>
+<br>
+ Previously text regions had their own arithmetic/huffman<br>
+ decoding contexts/tables, separate from those used to decode<br>
+ fields in the symbol dictionary itself. This is incorrect.<br>
+<br>
+ Annex E.3.7 describes how to reset the arithmetic coding<br>
+ contexts. Only the top-level symbol dictionary decoding<br>
+ procedure described in chapter 7.4.2.2 references this<br>
+ annex.<br>
+<br>
+ Neither the symbol dictionary decoding procedure outlined<br>
+ in chapter 6.5 in the specification, nor chapter 6.5.8<br>
+ describing how to decode the symbol bitmap itself (and<br>
+ thereby implicitly chapter 6.2 describing the generic<br>
+ region decoding procedure, 6.4 explaining the text<br>
+ region decoding procedure and 6.5.8.2.2 describing how to<br>
+ decode bitmaps with only one symbol in the<br>
+ refinement/aggregate coding) refer to annex E.3.7.<br>
+<br>
+ It is therefore incorrect to separate the arithmetic<br>
+ integer decoding contexts from the ones used to parse<br>
+ the symbol dictionary fields as the specification calls<br>
+ for these to be reused.<br>
+<br>
+ This created a problem when decoding page 3 in the sample<br>
+ bitstream in Annex H.1. More specifically in Annex H.1,<br>
+ step 37 (f) xi E where the refinement flag was decoded as<br>
+ 3 instead of the expected 0. This was because the IAID<br>
+ arithmetic coding context used in step 37 (f) xi D had<br>
+ not been shared with that in step 37 (f) v as is expected<br>
+ in the specification. The result was that page 3 of the<br>
+ sample bitstream was never decoded. Potentially this may<br>
+ also have affected other JBIG2 bitstreams.<br>
+<br>
+ Sharing the arithmetic coding contexts between the symbol<br>
+ dictionary decoding procedure and the text region decoder<br>
+ resolves the issue<br>
+<br>
+jbig2dec/jbig2_symbol_dict.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-06-18 18:48:49 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d7b659b9853059ddd1d5ecaab79de16a7f675b32">d7b659b9853059ddd1d5ecaab79de16a7f675b32</a>
+<blockquote>
+<p>
+ jbig2dec: Handle very large symbol code lengths without overflowing.<br>
+<br>
+jbig2dec/jbig2_symbol_dict.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-04-25 02:33:52 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=62df49ab137726635c9f3d2f76c0b599d733e8b5">62df49ab137726635c9f3d2f76c0b599d733e8b5</a>
+<blockquote>
+<p>
+ jbig2dec: Reorder test for huffman decoding vs arithmetic integer decoding.<br>
+<br>
+jbig2dec/jbig2_symbol_dict.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-04-25 02:27:59 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fdf1504cb5dfbe77b0458ccad025fc992df77ad8">fdf1504cb5dfbe77b0458ccad025fc992df77ad8</a>
+<blockquote>
+<p>
+ jbig2dec: Move text region decoder parameters initialization.<br>
+<br>
+ Previously the text region decoder parameters were only initialized<br>
+ once a text region was about to be decoded. Now they are initialized<br>
+ at the beginning of the decoding of the symbol dictionary. This<br>
+ prepares for sharing of the IAID, IARDX and IARDY arithmetic<br>
+ integer decoder contexts as well as the SBHUFFRDX, SBHUFFRDY and<br>
+ SBHUFFRSIZE huffman tables between the text region decoder and the<br>
+ symbol dictionary parser itself.<br>
+<br>
+jbig2dec/jbig2_symbol_dict.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-04-25 02:16:29 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e32e214b5de77ca1b658e46ae8d7cc6cabfb9d62">e32e214b5de77ca1b658e46ae8d7cc6cabfb9d62</a>
+<blockquote>
+<p>
+ jbig2dec: Simplify cleanup when parsing symbol dictionary.<br>
+<br>
+ In the process move all cleanup, including any intermediate<br>
+ images to the cleanup section towards the end of the symbol<br>
+ decoding function.<br>
+<br>
+jbig2dec/jbig2_symbol_dict.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-04-25 02:11:00 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=94a5d891cb5cf495b4d2bb8460b293b39e1603ce">94a5d891cb5cf495b4d2bb8460b293b39e1603ce</a>
+<blockquote>
+<p>
+ jbig2dec: Initialize huffman table for size of symbols refinement data.<br>
+<br>
+ Previously this was uninitialized, possibly leading to dereferencing<br>
+ an uninitialized table pointer.<br>
+<br>
+jbig2dec/jbig2_symbol_dict.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-04-25 01:57:52 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a27e623cac13c67926c42222589ff87f76f369dc">a27e623cac13c67926c42222589ff87f76f369dc</a>
+<blockquote>
+<p>
+ jbig2dec: Let symbol refinement Y offset use its own huffman table.<br>
+<br>
+ Previously both the symbol instances refinement X and Y offset reused<br>
+ the same table SBHUFFRDX, but according to 6.4.11.3 and 6.4.11.4 in<br>
+ the specification they ought to be using the independent SBHUFFRDX<br>
+ and SBHUFFRDY tables. Let's make it so.<br>
+<br>
+jbig2dec/jbig2_symbol_dict.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-04-25 01:50:07 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=721338e0846bc0e50cf4528ba6b0d54b1a577db4">721338e0846bc0e50cf4528ba6b0d54b1a577db4</a>
+<blockquote>
+<p>
+ jbig2dec: Remember to put all new symbols into ref/agg dictionary.<br>
+<br>
+ Previously the symbol dictionary propagated to the text region<br>
+ decoder for a refinement/aggregate coded symbol did not contain<br>
+ all necessary symbols. Only the symbols in the symbol dictionaries<br>
+ referred to (SDINSYMS) by the currently parsed symbol dictionary<br>
+ would be propagated into the text region decoder (SBSYMS).<br>
+<br>
+ Table 17 in the specification states that SBSYMS should be set<br>
+ according to 6.5.8.2.4 which clearly states that SDINSYMS as well<br>
+ as any symbols decoded up to that point (NSYMSDECODED symbols in<br>
+ SDNEWSYMS) ought to be introduced into the dictionary that is<br>
+ propagated to the text region decoder (SBSYMS). This is now done<br>
+ by providing the text region decoder not just with a single symbol<br>
+ dictionary, but both with SDINSYMS and SDNEWSYMS allowing the<br>
+ decoder to refer to symbols from both.<br>
+<br>
+jbig2dec/jbig2_symbol_dict.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-04-24 22:32:16 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9eab580c634eb61d9340ebc40f4c40174ed226c5">9eab580c634eb61d9340ebc40f4c40174ed226c5</a>
+<blockquote>
+<p>
+ jbig2dec: Paper over the fact that VS 2010 and earlier may not have SIZE_MAX.<br>
+<br>
+jbig2dec/config_win32.h<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-04-20 02:33:31 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0ee7f3b1c19f6d777eaf6bdf2b8ea8d241bf49d4">0ee7f3b1c19f6d777eaf6bdf2b8ea8d241bf49d4</a>
+<blockquote>
+<p>
+ jbig2dec: Check for T.88 amendments 2/3 bitstreams.<br>
+<br>
+ T.88 Amendment 2 adds up to 12 adaptive template pixels in generic regions.<br>
+ T.88 Amendment 3 adds support for generic/text regions to encode colors.<br>
+ Neither amendment is implemented and no sample files have been found.<br>
+ Return fatal errors for such bitstreams/files for the time being.<br>
+<br>
+jbig2dec/jbig2.c<br>
+jbig2dec/jbig2_generic.c<br>
+jbig2dec/jbig2_page.c<br>
+jbig2dec/jbig2_segment.c<br>
+jbig2dec/jbig2_text.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-04-24 13:39:07 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b200c6e476d00e760100b0b3e23f6e57f0794969">b200c6e476d00e760100b0b3e23f6e57f0794969</a>
+<blockquote>
+<p>
+ jbig2dec: Handle under-/overflow in arithmetic integer decoder.<br>
+<br>
+jbig2dec/jbig2_arith_int.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-04-24 13:54:47 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d73eadc850bd8b4f3bd26a70d7916de9f5c824c8">d73eadc850bd8b4f3bd26a70d7916de9f5c824c8</a>
+<blockquote>
+<p>
+ jbig2dec: Rename variables to closely follow the specification.<br>
+<br>
+jbig2dec/jbig2_refinement.c<br>
+jbig2dec/jbig2_refinement.h<br>
+jbig2dec/jbig2_symbol_dict.c<br>
+jbig2dec/jbig2_text.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-04-24 04:01:13 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f135d8f51b7a3da455c6cd4ccd88c5f6ab7f930b">f135d8f51b7a3da455c6cd4ccd88c5f6ab7f930b</a>
+<blockquote>
+<p>
+ jbig2dec: Implement support for resizing image width.<br>
+<br>
+jbig2dec/jbig2_image.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-04-24 03:48:35 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fe83cea1333445c0273e45003d6eeb172bc82e0e">fe83cea1333445c0273e45003d6eeb172bc82e0e</a>
+<blockquote>
+<p>
+ jbig2dec: When extending image use default page color.<br>
+<br>
+jbig2dec/jbig2_image.c<br>
+jbig2dec/jbig2_image.h<br>
+jbig2dec/jbig2_page.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-04-24 03:40:06 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=95df4340d0d65c1f5f180d31a93e8806ddb345dd">95df4340d0d65c1f5f180d31a93e8806ddb345dd</a>
+<blockquote>
+<p>
+ jbig2dec: Clarify lack of support for dependency bit.<br>
+<br>
+ The extension segment dependency bit only matters for<br>
+ encoders. This is because it informs the encoder what<br>
+ other segments a specific segment depends on. Since<br>
+ jbig2dec doesn't do any alteration of segments this<br>
+ need not be supported (or indeed even parsed).<br>
+<br>
+jbig2dec/jbig2_segment.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-04-24 23:57:18 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=edb5c4000cc7e38c1f9f5e93243ab1737e13aeee">edb5c4000cc7e38c1f9f5e93243ab1737e13aeee</a>
+<blockquote>
+<p>
+ jbig2dec: Move arithmetic decoder test logging inside test.<br>
+<br>
+ Also take the opportunity to make the test stream static.<br>
+<br>
+jbig2dec/jbig2_arith.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-04-24 04:51:31 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3a2b2f13a26355a0ca7dc58d7c28276df3d7b786">3a2b2f13a26355a0ca7dc58d7c28276df3d7b786</a>
+<blockquote>
+<p>
+ jbig2dec: Enable both huffman tests when running check.<br>
+<br>
+jbig2dec/jbig2_huffman.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-04-23 14:02:46 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=db1efdfb5f194079070bfd1ab50ae11e881de50d">db1efdfb5f194079070bfd1ab50ae11e881de50d</a>
+<blockquote>
+<p>
+ jbig2dec: Handle get_next_word() returning error/less than a word.<br>
+<br>
+ This includes propagating the error handling to all callers.<br>
+<br>
+jbig2dec/jbig2_arith.c<br>
+jbig2dec/jbig2_huffman.c<br>
+jbig2dec/jbig2_huffman.h<br>
+jbig2dec/jbig2_symbol_dict.c<br>
+jbig2dec/jbig2_text.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-04-24 20:05:39 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=968c424a70471c086466568bee21097e89149663">968c424a70471c086466568bee21097e89149663</a>
+<blockquote>
+<p>
+ jbig2dec: free/release functions must handle NULL argument.<br>
+<br>
+jbig2dec/jbig2.c<br>
+jbig2dec/jbig2_halftone.c<br>
+jbig2dec/jbig2_huffman.c<br>
+jbig2dec/jbig2_image.c<br>
+jbig2dec/jbig2_metadata.c<br>
+jbig2dec/jbig2_page.c<br>
+jbig2dec/jbig2_segment.c<br>
+jbig2dec/jbig2_symbol_dict.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-04-11 00:02:39 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a21e4d7cf5b7928c490a2f804dfc01fc66069e35">a21e4d7cf5b7928c490a2f804dfc01fc66069e35</a>
+<blockquote>
+<p>
+ jbig2dec: Implement pixel out of field test for refinement regions too.<br>
+<br>
+jbig2dec/jbig2_refinement.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-04-21 23:36:54 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=01ae24d85f67b3c1b11993f1644a71da643ecc9b">01ae24d85f67b3c1b11993f1644a71da643ecc9b</a>
+<blockquote>
+<p>
+ jbig2dec: Differentiate error messages in generic region decoder.<br>
+<br>
+ This makes it easier to know from where the error message originated.<br>
+<br>
+jbig2dec/jbig2_generic.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-04-22 01:45:15 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f920a1839a66b844651b2ff5524944b0dd9484cf">f920a1839a66b844651b2ff5524944b0dd9484cf</a>
+<blockquote>
+<p>
+ jbig2dec: Fix and use decoder for template 3 generic regions.<br>
+<br>
+ Previously an optimized implementation for template generic<br>
+ regions was commented out, presumably because it was faulty,<br>
+ but now once the implementation is fixed it may be used.<br>
+<br>
+ The PDF in bug 693617 has an object 25 that contains a JBIG2<br>
+ bitstream that can use this fix optimized decoder. Without<br>
+ the fix in the optimized decoder the rendered output image<br>
+ is incorrect.<br>
+<br>
+jbig2dec/jbig2_generic.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-04-23 01:25:34 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8e1b5e97f0950a47be4094028cf242a2b2861a07">8e1b5e97f0950a47be4094028cf242a2b2861a07</a>
+<blockquote>
+<p>
+ jbig2dec: Handle non-nominal adaptive pixel locations in template 2.<br>
+<br>
+ Optimized generic region decoders can only handle nominal<br>
+ adaptive pixel locations, while the unoptimized generic region<br>
+ decoders can handle them being located at any location.<br>
+<br>
+ Previously the optimized decode was always used regardless of the<br>
+ locations of the adaptive pixels, possibly causing decoding<br>
+ issues. Now an unoptimized decoder is added for template 2 and is<br>
+ being used whenever the adaptive pixel locations are at non-nominal<br>
+ locations.<br>
+<br>
+jbig2dec/jbig2_generic.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-04-23 01:28:14 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c389757b311d9e01cf98cfb5d56c500929e28c43">c389757b311d9e01cf98cfb5d56c500929e28c43</a>
+<blockquote>
+<p>
+ jbig2dec: Handle non-nominal adaptive pixel locations in template 1.<br>
+<br>
+ Optimized generic region decoders can only handle nominal<br>
+ adaptive pixel locations, while the unoptimized generic region<br>
+ decoders can handle them being located at any location.<br>
+<br>
+ Previously the optimized decode was always used regardless of the<br>
+ locations of the adaptive pixels, possibly causing decoding<br>
+ issues. Now an unoptimized decoder is added for template 1 and is<br>
+ being used whenever the adaptive pixel locations are at non-nominal<br>
+ locations.<br>
+<br>
+jbig2dec/jbig2_generic.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-04-09 22:25:34 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d522f9a9815dce16977f7a9e9715e861cab76a55">d522f9a9815dce16977f7a9e9715e861cab76a55</a>
+<blockquote>
+<p>
+ jbig2dec: Fix incorrect adaptive pixel location check.<br>
+<br>
+ Previously for the adaptive pixel template 2 the check for the<br>
+ location of the adaptive pixel was wrong. Because generic regions<br>
+ with nominal locations are more common this lead to the<br>
+ unoptimized decoder being used. Only a few images where the<br>
+ adaptive pixel location happened to be at this wrong location<br>
+ used the optimized decoder, and presumably were decoded<br>
+ incorrectly. This incorrect location check therefore hid the bug<br>
+ in the optimized generic region decoder concerning what pixels<br>
+ are included at what location in the arithmetic integer context.<br>
+<br>
+ Now the adaptive pixel location check is corrected as well as the<br>
+ bug in the optimized generic region decoder itself.<br>
+<br>
+jbig2dec/jbig2_generic.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-05-24 03:27:21 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=18a051f2f422f9d336e1d6a28f990068faaf2abc">18a051f2f422f9d336e1d6a28f990068faaf2abc</a>
+<blockquote>
+<p>
+ jbig2dec: Differentiate between errors/OOB when decoding BMSIZE.<br>
+<br>
+ Previously the two very lumped together, causing a single error message.<br>
+<br>
+jbig2dec/jbig2_symbol_dict.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-04-24 13:39:46 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=851e3885386f992af8e73ba90c8b8fcf5a6cb69a">851e3885386f992af8e73ba90c8b8fcf5a6cb69a</a>
+<blockquote>
+<p>
+ jbig2dec: Print errors when out of boundary values occur.<br>
+<br>
+ According to the specification in 6.4.5 when decoding text<br>
+ regions, where OOB values in IDS indicate that the last symbol<br>
+ in a strip has been decoded, or in 6.5.5 when decoding symbol<br>
+ dictionaries, where OOB values in DW indicate that all the<br>
+ symbols in a height class have been decoded. When decoding any<br>
+ other symbols than IDS or DW, OOB values are not expected, so<br>
+ report these as fatal errors.<br>
+<br>
+jbig2dec/jbig2_symbol_dict.c<br>
+jbig2dec/jbig2_text.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-04-25 02:08:40 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6f4075cae5c70e5f766a79d011624326c4bf5185">6f4075cae5c70e5f766a79d011624326c4bf5185</a>
+<blockquote>
+<p>
+ jbig2dec: Check if all arithmetic decoder contexts are initialized.<br>
+<br>
+ Previously the IADT and IARI contexts were never checked for having<br>
+ been successfully initialized, possibly causing uninitialized data<br>
+ issues later.<br>
+<br>
+jbig2dec/jbig2_symbol_dict.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-05-24 03:28:04 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7241bffe648d3f75cd03bbaa404fc927163e6215">7241bffe648d3f75cd03bbaa404fc927163e6215</a>
+<blockquote>
+<p>
+ jbig2dec: Skip over undecoded pages when getting pages.<br>
+<br>
+jbig2dec/jbig2_page.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-05-24 03:23:25 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7b68d2964935c40fe8f58a9540c5765fb2f53f0f">7b68d2964935c40fe8f58a9540c5765fb2f53f0f</a>
+<blockquote>
+<p>
+ jbig2dec: Detect NULL image pointer before trying to take reference.<br>
+<br>
+ Attempting to take a reference to NULL is a no-op anyway.<br>
+<br>
+jbig2dec/jbig2_refinement.c<br>
+jbig2dec/jbig2_text.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-06-01 10:36:53 -0700
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f8f900369183f908fb8e8796154e2c7b57fbd202">f8f900369183f908fb8e8796154e2c7b57fbd202</a>
+<blockquote>
+<p>
+ jbig2dec: Rename jbig2_image_clone() to jbig2_image_reference().<br>
+<br>
+ This more accurately explains what the function does, and<br>
+ mirrors jbig2_image_release() quite well.<br>
+<br>
+jbig2dec/jbig2_image.c<br>
+jbig2dec/jbig2_image.h<br>
+jbig2dec/jbig2_page.c<br>
+jbig2dec/jbig2_refinement.c<br>
+jbig2dec/jbig2_symbol_dict.c<br>
+jbig2dec/jbig2_text.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-05-24 03:24:33 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c3707893650d631dfcc4ca5a99b2eb28f7108fd9">c3707893650d631dfcc4ca5a99b2eb28f7108fd9</a>
+<blockquote>
+<p>
+ jbig2dec: Refinement bitmaps without images should be treated as fatal errors.<br>
+<br>
+jbig2dec/jbig2_refinement.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-05-23 23:12:16 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=dc80246ab0a08f3c946d43d930c772dedb8b7bf4">dc80246ab0a08f3c946d43d930c772dedb8b7bf4</a>
+<blockquote>
+<p>
+ jbig2dec: Report warnings if called functions indicate errors.<br>
+<br>
+ The first error detected ought to be a fatal error, but when this<br>
+ error condition is propagated to callers, they should indicate warnings.<br>
+<br>
+jbig2dec/jbig2.c<br>
+jbig2dec/jbig2_generic.c<br>
+jbig2dec/jbig2_halftone.c<br>
+jbig2dec/jbig2_page.c<br>
+jbig2dec/jbig2_refinement.c<br>
+jbig2dec/jbig2_symbol_dict.c<br>
+jbig2dec/jbig2_text.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-05-27 02:51:10 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=689fa69bfd6c423194e58f22835836870cb519b5">689fa69bfd6c423194e58f22835836870cb519b5</a>
+<blockquote>
+<p>
+ jbig2dec: Unsupported intermediate generic region is now a fatal error.<br>
+<br>
+jbig2dec/jbig2_segment.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-05-27 02:50:32 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f394d8e7b5588bed1c2265136da0bcb2502507fb">f394d8e7b5588bed1c2265136da0bcb2502507fb</a>
+<blockquote>
+<p>
+ jbig2dec: Halftone regions with skip enabled is now a fatal error.<br>
+<br>
+jbig2dec/jbig2_halftone.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-05-24 03:20:52 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=de4b96e07690cde1999554b1413d79f20d1e8523">de4b96e07690cde1999554b1413d79f20d1e8523</a>
+<blockquote>
+<p>
+ jbig2dec: Detected errors should be fatal, not warnings.<br>
+<br>
+jbig2dec/jbig2_generic.c<br>
+jbig2dec/jbig2_metadata.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-05-23 21:48:31 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d175962540cd0ff2b6dcec2a13bf61a17df93741">d175962540cd0ff2b6dcec2a13bf61a17df93741</a>
+<blockquote>
+<p>
+ jbig2dec: Remember to free IAID context upon error.<br>
+<br>
+ Previously this might result in a memory leak.<br>
+<br>
+jbig2dec/jbig2_arith_iaid.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-05-24 00:52:15 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e32e5535ca5055e31417d022753eed67a30d482e">e32e5535ca5055e31417d022753eed67a30d482e</a>
+<blockquote>
+<p>
+ jbig2dec: Free referred to symbol dictionary upon error.<br>
+<br>
+jbig2dec/jbig2_symbol_dict.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-05-24 03:26:43 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fc4940d6aabebd6516befefc0b51676ccc332a7f">fc4940d6aabebd6516befefc0b51676ccc332a7f</a>
+<blockquote>
+<p>
+ jbig2dec: Pages without decoded images cannot be completed.<br>
+<br>
+jbig2dec/jbig2_page.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-05-24 00:51:20 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e4e1e6ac335eaccd92eff57308e173ac67a392f0">e4e1e6ac335eaccd92eff57308e173ac67a392f0</a>
+<blockquote>
+<p>
+ jbig2dec: When a page fails to complete, handle as an error.<br>
+<br>
+ Previously this only caused a warning message but didn't fail,<br>
+ but failing to complete a page means the parsing is somehow broken,<br>
+ and so it ought to be best to treat it as a fatal error.<br>
+<br>
+jbig2dec/jbig2dec.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-05-24 00:33:18 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3da06c6284e3370f31382299eddf7c76f11960cd">3da06c6284e3370f31382299eddf7c76f11960cd</a>
+<blockquote>
+<p>
+ jbig2dec: Releasing a page cannot not fail.<br>
+<br>
+ It can only fail if you supply a random page pointer.<br>
+ Don't do that it would be a programming error.<br>
+<br>
+jbig2dec/jbig2.h<br>
+jbig2dec/jbig2_page.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-05-23 23:21:27 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=451ee5588ec2616afc21ae9ccc61c2afb8144bf7">451ee5588ec2616afc21ae9ccc61c2afb8144bf7</a>
+<blockquote>
+<p>
+ jbig2dec: Directly return jbig2_error(FATAL); they indicate errors.<br>
+<br>
+ Because jbig2_error(ctx, JBIG2_SEVERITY_FATAL, ...) returns -1,<br>
+ it can be immediately returned or assigned as a return code.<br>
+<br>
+jbig2dec/jbig2_huffman.c<br>
+jbig2dec/jbig2_metadata.c<br>
+jbig2dec/jbig2_text.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-05-23 23:12:43 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1e751b882e18fee36a16488e7b46c0e1b571d605">1e751b882e18fee36a16488e7b46c0e1b571d605</a>
+<blockquote>
+<p>
+ jbig2dec: Return jbig2_error(WARNING); they indicate errors.<br>
+<br>
+ Because jbig2_error(ctx, JBIG2_SEVERITY_WARNING, ...) now returns -1,<br>
+ it can be immediately returned or assigned as a return code.<br>
+<br>
+jbig2dec/jbig2_generic.c<br>
+jbig2dec/jbig2_halftone.c<br>
+jbig2dec/jbig2_metadata.c<br>
+jbig2dec/jbig2_mmr.c<br>
+jbig2dec/jbig2_page.c<br>
+jbig2dec/jbig2_symbol_dict.c<br>
+jbig2dec/jbig2_text.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-05-24 01:24:32 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c159c4534b9b9af4998d6dcdee896fe2197fa542">c159c4534b9b9af4998d6dcdee896fe2197fa542</a>
+<blockquote>
+<p>
+ jbig2dec: Convert debug messages in debug code to warnings.<br>
+<br>
+ This is because the debug code calls functions that write<br>
+ PBM images or similar, these may fail and when this happens<br>
+ the calling function ought to print a warning and fail itself.<br>
+<br>
+jbig2dec/jbig2_page.c<br>
+jbig2dec/jbig2_refinement.c<br>
+jbig2dec/jbig2_symbol_dict.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-05-23 00:22:41 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a8b6f19d5f5e7af568c448421c24bbe200ea9c89">a8b6f19d5f5e7af568c448421c24bbe200ea9c89</a>
+<blockquote>
+<p>
+ jbig2dec: Error callback should not modify jbig2_error() return code.<br>
+<br>
+ If a function detects an error it should call<br>
+ jbig2_error(ctx, JBIG2_SEVERITY_FATAL, ...) and return -1. The caller<br>
+ of this function may then detect the return code indicating error<br>
+ and call jbig2_error(ctx, JBIG2_SEVERITY_WARNING, ...). Previously<br>
+ this latter call to jbig2_error() would not return -1, but it is good<br>
+ form for the calling function to fail and return -1 to the next caller.<br>
+ Therefore the error callback no longer has the option to override the<br>
+ return code from jbig2_error(), instead jbig2_error() always returns -1.<br>
+<br>
+base/sjbig2.c<br>
+jbig2dec/jbig2.c<br>
+jbig2dec/jbig2.h<br>
+jbig2dec/jbig2dec.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-05-23 02:00:49 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2c743c193e1812795c9c23a8c6cc9d69d2a47eb5">2c743c193e1812795c9c23a8c6cc9d69d2a47eb5</a>
+<blockquote>
+<p>
+ jbig2dec: Only return jbig2_error() for fatal errors/warnings.<br>
+<br>
+ Only calls to jbig2_error() using fatal errors or warnings may<br>
+ return, no calls to jbig2_error() using informational or debug<br>
+ messages may return. This is preparation for jbig2_error() to<br>
+ always return -1 for errors/warnings.<br>
+<br>
+jbig2dec/jbig2_refinement.c<br>
+jbig2dec/jbig2_segment.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-04-06 23:43:51 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=be59a40717ec60a5a054ccf88f7064c90788aa78">be59a40717ec60a5a054ccf88f7064c90788aa78</a>
+<blockquote>
+<p>
+ jbig2dec: Add support to process embedded JBIG2 bitstreams.<br>
+<br>
+ This type of stream is present in PDF files which is a good source<br>
+ of test streams for jbig2dec.<br>
+<br>
+jbig2dec/jbig2dec.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-04-24 04:19:31 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d7f529ac50d61a1fe07eb1a667322234402e9894">d7f529ac50d61a1fe07eb1a667322234402e9894</a>
+<blockquote>
+<p>
+ jbig2dec: Remove check for bitmap coding context use.<br>
+<br>
+ The removed check used bitmask 0x80 to check for the flag<br>
+ &quot;bitmap coding context used&quot; among the symbol dictionary flags.<br>
+ The correct bitmask is 0x100, which was already checked for<br>
+ later in the code, rendering this incorrect check unnecessary.<br>
+<br>
+jbig2dec/jbig2_symbol_dict.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-04-22 16:11:32 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=22fbf1bb62b49316452c7556399618399c463039">22fbf1bb62b49316452c7556399618399c463039</a>
+<blockquote>
+<p>
+ jbig2dec: Return error code from get_next_word().<br>
+<br>
+ Previously Jbig2WordStream's get_next_word() callback<br>
+ sometimes returned error codes. This contradicted the<br>
+ declaration of the callback. However indicating errors<br>
+ and the number of bytes returned upon successful calls<br>
+ is a good idea. The declaration and all implementations<br>
+ of the callback have been adjusted accordingly.<br>
+<br>
+ This means that jbig2dec now compiles without warnings.<br>
+<br>
+jbig2dec/jbig2.c<br>
+jbig2dec/jbig2_arith.c<br>
+jbig2dec/jbig2_huffman.c<br>
+jbig2dec/jbig2_priv.h<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-04-25 05:01:41 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ef05820d514fd6a27d1b7690df16b63f8b20cf26">ef05820d514fd6a27d1b7690df16b63f8b20cf26</a>
+<blockquote>
+<p>
+ jbig2dec: Indicate success when using arithmetic decoder.<br>
+<br>
+ Commit 2b2dcf4ccf401ed210f03c858b304994749fd2b3 accidentally<br>
+ forgot to set the out parameter to indicate success when the<br>
+ call was indeed successful.<br>
+<br>
+jbig2dec/jbig2_arith.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-05-23 20:05:20 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=359a15e1c8b460268ff80fb8e8a5da121fcbafc3">359a15e1c8b460268ff80fb8e8a5da121fcbafc3</a>
+<blockquote>
+<p>
+ jbig2dec: Avoid NULL-check before jbig2_free()/jbig2_image_release().<br>
+<br>
+jbig2dec/jbig2_halftone.c<br>
+jbig2dec/jbig2_huffman.c<br>
+jbig2dec/jbig2_segment.c<br>
+jbig2dec/jbig2_symbol_dict.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-05-23 00:04:55 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b9f15473bdd8f48b9336b67d15dc08a6f78f750b">b9f15473bdd8f48b9336b67d15dc08a6f78f750b</a>
+<blockquote>
+<p>
+ jbig2dec: Move declarations from jbig2_priv.h to their respective headers.<br>
+<br>
+ Due to this some .c-files now need new includes.<br>
+<br>
+jbig2dec/jbig2.c<br>
+jbig2dec/jbig2.h<br>
+jbig2dec/jbig2_generic.c<br>
+jbig2dec/jbig2_generic.h<br>
+jbig2dec/jbig2_halftone.c<br>
+jbig2dec/jbig2_halftone.h<br>
+jbig2dec/jbig2_huffman.c<br>
+jbig2dec/jbig2_image.h<br>
+jbig2dec/jbig2_metadata.c<br>
+jbig2dec/jbig2_page.c<br>
+jbig2dec/jbig2_priv.h<br>
+jbig2dec/jbig2_segment.c<br>
+jbig2dec/jbig2_symbol_dict.c<br>
+jbig2dec/jbig2_text.c<br>
+jbig2dec/jbig2_text.h<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-05-26 19:12:28 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c6d6efdc340e0cac31cda1bbb654bcbfcda92b47">c6d6efdc340e0cac31cda1bbb654bcbfcda92b47</a>
+<blockquote>
+<p>
+ jbig2dec: Create jbig2_segment.h with segment declarations.<br>
+<br>
+jbig2dec/jbig2.c<br>
+jbig2dec/jbig2.h<br>
+jbig2dec/jbig2_generic.c<br>
+jbig2dec/jbig2_halftone.c<br>
+jbig2dec/jbig2_huffman.c<br>
+jbig2dec/jbig2_metadata.c<br>
+jbig2dec/jbig2_page.c<br>
+jbig2dec/jbig2_priv.h<br>
+jbig2dec/jbig2_refinement.c<br>
+jbig2dec/jbig2_segment.c<br>
+jbig2dec/jbig2_segment.h<br>
+jbig2dec/jbig2_symbol_dict.c<br>
+jbig2dec/jbig2_text.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-05-26 15:00:00 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=624bc3cc86c95bc6215d02d6bf39ff694e2c2a9d">624bc3cc86c95bc6215d02d6bf39ff694e2c2a9d</a>
+<blockquote>
+<p>
+ jbig2dec: Create jbig2_refinement.h with refinement declarations.<br>
+<br>
+jbig2dec/jbig2_generic.h<br>
+jbig2dec/jbig2_priv.h<br>
+jbig2dec/jbig2_refinement.c<br>
+jbig2dec/jbig2_refinement.h<br>
+jbig2dec/jbig2_segment.c<br>
+jbig2dec/jbig2_symbol_dict.c<br>
+jbig2dec/jbig2_text.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-05-26 14:51:42 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8f4288807d659f72734d41dd8b7d434b1e15dfc2">8f4288807d659f72734d41dd8b7d434b1e15dfc2</a>
+<blockquote>
+<p>
+ jbig2dec: Create jbig2_page.h with page declarations.<br>
+<br>
+jbig2dec/jbig2.c<br>
+jbig2dec/jbig2_generic.c<br>
+jbig2dec/jbig2_halftone.c<br>
+jbig2dec/jbig2_page.c<br>
+jbig2dec/jbig2_page.h<br>
+jbig2dec/jbig2_priv.h<br>
+jbig2dec/jbig2_refinement.c<br>
+jbig2dec/jbig2_segment.c<br>
+jbig2dec/jbig2_text.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-05-26 15:12:54 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=55925ee6220fe371b1fe34fdc27cfd4dad8847b2">55925ee6220fe371b1fe34fdc27cfd4dad8847b2</a>
+<blockquote>
+<p>
+ jbig2dec: Create jbig2_image_rw.h with image reading/writing declarations.<br>
+<br>
+jbig2dec/jbig2_image.h<br>
+jbig2dec/jbig2_image_pbm.c<br>
+jbig2dec/jbig2_image_rw.h<br>
+jbig2dec/jbig2dec.c<br>
+jbig2dec/pbm2png.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-05-26 15:01:37 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f7d2387f73488a24db04b22884d1e2c7bb83a857">f7d2387f73488a24db04b22884d1e2c7bb83a857</a>
+<blockquote>
+<p>
+ jbig2dec: Remove non-existing function from header.<br>
+<br>
+jbig2dec/jbig2_priv.h<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-05-24 23:54:54 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cbb2072c14305de22f2334acf44a080933f26e21">cbb2072c14305de22f2334acf44a080933f26e21</a>
+<blockquote>
+<p>
+ jbig2dec: Add include guards to all headers.<br>
+<br>
+jbig2dec/jbig2_arith.h<br>
+jbig2dec/jbig2_arith_iaid.h<br>
+jbig2dec/jbig2_arith_int.h<br>
+jbig2dec/jbig2_generic.h<br>
+jbig2dec/jbig2_huffman.h<br>
+jbig2dec/jbig2_hufftab.h<br>
+jbig2dec/jbig2_mmr.h<br>
+jbig2dec/jbig2_priv.h<br>
+jbig2dec/jbig2_symbol_dict.h<br>
+jbig2dec/jbig2_text.h<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-05-24 03:18:04 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6cc76f397ff5af382e4e49914d1b42df3e0a78e4">6cc76f397ff5af382e4e49914d1b42df3e0a78e4</a>
+<blockquote>
+<p>
+ jbig2dec: Rephrase error messages.<br>
+<br>
+jbig2dec/jbig2.c<br>
+jbig2dec/jbig2_arith_int.c<br>
+jbig2dec/jbig2_generic.c<br>
+jbig2dec/jbig2_halftone.c<br>
+jbig2dec/jbig2_huffman.c<br>
+jbig2dec/jbig2_image.c<br>
+jbig2dec/jbig2_image_png.c<br>
+jbig2dec/jbig2_mmr.c<br>
+jbig2dec/jbig2_page.c<br>
+jbig2dec/jbig2_refinement.c<br>
+jbig2dec/jbig2_segment.c<br>
+jbig2dec/jbig2_symbol_dict.c<br>
+jbig2dec/jbig2_text.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-05-24 02:05:36 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=344a90c91dc03e9ae80500303e67594f175374e3">344a90c91dc03e9ae80500303e67594f175374e3</a>
+<blockquote>
+<p>
+ jbig2dec: Remove unnecessary scoping.<br>
+<br>
+jbig2dec/jbig2_refinement.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-04-25 00:50:12 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=120732b27011a1651ebfcf50536cac953c7b4c9b">120732b27011a1651ebfcf50536cac953c7b4c9b</a>
+<blockquote>
+<p>
+ jbig2dec: Remove many unnecessary parentheses.<br>
+<br>
+jbig2dec/jbig2_page.c<br>
+jbig2dec/jbig2_symbol_dict.c<br>
+jbig2dec/jbig2_text.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-04-22 23:08:49 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b3d2e786ace758422cdeb22c1cc688bb52087ddf">b3d2e786ace758422cdeb22c1cc688bb52087ddf</a>
+<blockquote>
+<p>
+ jbig2dec: Remove unnecessary comments, whitespace and unused code.<br>
+<br>
+jbig2dec/jbig2.c<br>
+jbig2dec/jbig2_generic.c<br>
+jbig2dec/jbig2_halftone.c<br>
+jbig2dec/jbig2_huffman.c<br>
+jbig2dec/jbig2_image.c<br>
+jbig2dec/jbig2_page.c<br>
+jbig2dec/jbig2_refinement.c<br>
+jbig2dec/jbig2_segment.c<br>
+jbig2dec/jbig2_symbol_dict.c<br>
+jbig2dec/jbig2_text.c<br>
+jbig2dec/jbig2dec.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-05-08 22:35:11 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=def343c44322ebdf609d0113884385d944dc361a">def343c44322ebdf609d0113884385d944dc361a</a>
+<blockquote>
+<p>
+ jbig2dec: Fix typos in error messages and comments.<br>
+<br>
+jbig2dec/jbig2_halftone.c<br>
+jbig2dec/jbig2_huffman.c<br>
+jbig2dec/jbig2_metadata.c<br>
+jbig2dec/jbig2_page.c<br>
+jbig2dec/jbig2_symbol_dict.c<br>
+jbig2dec/jbig2dec.1<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-05-26 15:46:16 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a4ebc6d3cd3e2fcab8b3e9b7bcb7364c14f09d8d">a4ebc6d3cd3e2fcab8b3e9b7bcb7364c14f09d8d</a>
+<blockquote>
+<p>
+ jbig2dec: Reindent sources in the same way as before.<br>
+<br>
+ Accept some whitespace changes as done by the commands<br>
+ from commit d3d767d9b91ae7d82c261fbdfd735f3042161032.<br>
+<br>
+jbig2dec/jbig2.c<br>
+jbig2dec/jbig2_arith.h<br>
+jbig2dec/jbig2_halftone.c<br>
+jbig2dec/jbig2_image.c<br>
+jbig2dec/jbig2_metadata.c<br>
+jbig2dec/jbig2_mmr.c<br>
+jbig2dec/jbig2_page.c<br>
+jbig2dec/jbig2_priv.h<br>
+jbig2dec/jbig2_symbol_dict.c<br>
+jbig2dec/jbig2dec.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-07-12 16:35:12 +0100
+</strong>
+<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=bc6af8da1adc9b4939e3acbfc4194a143412af3c">bc6af8da1adc9b4939e3acbfc4194a143412af3c</a>
+<blockquote>
+<p>
+ Fix an error in the type 3 stitching function monotonic detection<br>
+<br>
+ Bug #699528 &quot;A rare edge condition can cause a function to incorrectly signal a rangecheck error&quot;<br>
+<br>
+ This is rather difficult to describe. The problem occurs when we try to<br>
+ check for monotonicity of a stitching function between two data points<br>
+ of the parametric variable.<br>
+<br>
+ We actually calculate a series of points between the two values and<br>
+ check to see that they all increase (or decrease). However, a stitching<br>
+ function can contain multiple functions, and so we break the range of<br>
+ values into groups at the limits of each function and check each<br>
+ group of values.<br>
+<br>
+ If the lower value of the parameteric variable is 'close' to the upper<br>
+ bound of the current function, we decide to 'punt' it up to the next<br>
+ function, presumably to avoid the overhead of a miniscule break. That is<br>
+ we simply don't bother calculating tiny amounts at the end of a function<br>
+ we just do the next function.<br>
+<br>
+ However, if the upper range of the parametric variable happened also<br>
+ to lie close to (but less than) the upper bound of the function, then<br>
+ when we used it to evaluate the next function in the array, it would lie<br>
+ below the bottom bound of that function, resulting in a rangecheck error.<br>
+<br>
+ This commit applies two fixes; firstly, if the upper and lower values<br>
+ of the parametric variable are the same then this is a point, and there<br>
+ is no point in checking it, so just jump straight out.<br>
+<br>
+ Secondly, the upper value is now promoted to the lower bound of the<br>
+ current function if it is less than that. This prevents us trying to<br>
+ use an out of bound value, in case we should somehow get both an upper<br>
+ *and* a lower bound which lie within the 'noise' threshold.<br>
+<br>
+ Because the range of 'noise' is so small (the bounds values of the<br>
+ function divided by 1 million) there is no practical likelihood of<br>
+ us missing a function which is not monotonic between those data<br>
+ points.<br>
+<br>
+base/gsfunc3.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2015-03-19 11:33:51 +0000
+</strong>
+<br>Tim Waugh &lt;twaugh@redhat.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=00c14a25c0f0d5e5e65d2d489045e566ccf436df">00c14a25c0f0d5e5e65d2d489045e566ccf436df</a>
+<blockquote>
+<p>
+ bug #695876: check that page margins don't overlap in cups driver.<br>
+<br>
+cups/gdevcups.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-07-10 09:51:37 +0100
+</strong>
+<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=87cfc860ea49a4a39c1198b419a019ed598416f0">87cfc860ea49a4a39c1198b419a019ed598416f0</a>
+<blockquote>
+<p>
+ PDF interpreter improve handling of PageLabels as pdfmark<br>
+<br>
+ Patch supplied by Leon Bottou, see Bug #696568. This improves the way<br>
+ the code handles the number tree when converting it to pdfmark<br>
+ operations.<br>
+<br>
+ I don't have any reasonable way to test this, as it relies on using a<br>
+ device which implements pdfmark, but doesn't implement WantsPageLabels<br>
+ (to avoid getting the number tree passed).<br>
+<br>
+Resource/Init/pdf_base.ps<br>
+Resource/Init/pdf_main.ps<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-07-10 08:50:11 +0100
+</strong>
+<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ac9f8412e8c35edd7c0bbbbcd1c7195a56bc15d8">ac9f8412e8c35edd7c0bbbbcd1c7195a56bc15d8</a>
+<blockquote>
+<p>
+ PDF interpreter - fix new PageLabels processing for non-pdfwrite case<br>
+<br>
+ The commit to treat PageLabels as pdfmark operations instead of using<br>
+ our internal code had a logical error when *not* using pdfwrite.<br>
+<br>
+ Committed verbatim as there's no simple way to test this case.<br>
+<br>
+Resource/Init/pdf_main.ps<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-07-09 09:24:27 -0700
+</strong>
+<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d45ebe705de7b7618ad0d0d20fc31a960c8d9ba2">d45ebe705de7b7618ad0d0d20fc31a960c8d9ba2</a>
+<blockquote>
+<p>
+ Bug 690339 - use free/alloc instead of resize when change frame buffer size<br>
+<br>
+ In gdev_prn_allocate(), when size of frame buffer changed, we used to call<br>
+ call gs_resize_object(). Now we call gs_free_object() followed by<br>
+ gs_alloc_bytes().<br>
+<br>
+ Two advantages -- avoids copying the old frame buffer to the new one<br>
+ (which was pointless) and now the old buffer and new buffer don't need<br>
+ to coexist, which could help on a low memory system.<br>
+<br>
+base/gdevprn.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-07-09 16:49:38 +0100
+</strong>
+<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9d168db605fba44e6238d53d8c29f5997760d2ca">9d168db605fba44e6238d53d8c29f5997760d2ca</a>
+<blockquote>
+<p>
+ device subclassing of patterns, use the correct memory structure<br>
+<br>
+ Spotted by Chris while looking at a customer problem, the customer's<br>
+ code allocs a new pattern accumulator using the device's memory, but it<br>
+ should really be using the current VM state of the interpreter.<br>
+<br>
+ The reason it didn't was because that information wasn't available at<br>
+ the point where the allocation is made. This commit adds the current<br>
+ interpreter VM mode to the 'param' structure, which enables us to pass<br>
+ it to th device, and have the device use it properly.<br>
+<br>
+base/gxdevsop.h<br>
+psi/zpcolor.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-07-09 14:16:31 +0100
+</strong>
+<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4f02acd487721451256d3348760cd3c9333e7635">4f02acd487721451256d3348760cd3c9333e7635</a>
+<blockquote>
+<p>
+ pdfwrite - allow PageLabels to be (optionally) transmitted as pdfmarks<br>
+<br>
+ Bug #696568 &quot;Treatment of page labels&quot;<br>
+<br>
+ Patch supplied by Leon Bottou, the creator and maintainer of the djvu<br>
+ device for Ghostscript, very slightly modified.<br>
+<br>
+ The djvu device wants the PageLabels from existing PDF files sent to<br>
+ the device as pdfmarks, exactly as they would be from PostScript. The<br>
+ problem with this from the pdfwrite point of view is that this would<br>
+ result in us unpicking the number tree to create pdfmark operations, and<br>
+ then at the pdfwrite end rebuilding a number tree to emit. Not rebuilding<br>
+ the tree would result in larger output.<br>
+<br>
+ This patch checks that the device implements pdfmark, and if it does<br>
+ checks whether WantsPageLabels is set in the device. If it is then we<br>
+ assume its pdfwrite (or a similar device prepared to accept the number<br>
+ tree). If it is not set then we walk the tree and create a new pdfmark<br>
+ for each page in the tree range.<br>
+<br>
+ I'm unable to test this properly, because it relies on a device which<br>
+ does implement pdfmark, but doesn't want PageLabels. Rudimentary<br>
+ testing seemed to work as expected, its possible that more complex<br>
+ examples might require some more work.<br>
+<br>
+Resource/Init/pdf_main.ps<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-07-06 09:58:06 +0100
+</strong>
+<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=42cee04f173ccacb6aafc8243dd6c2ef12cdde54">42cee04f173ccacb6aafc8243dd6c2ef12cdde54</a>
+<blockquote>
+<p>
+ Forgot to include the changed doc file in last commit<br>
+<br>
+doc/Use.htm<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-07-06 09:53:45 +0100
+</strong>
+<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cc826ca86485321cbc5fc111f7dad7ee39e69a17">cc826ca86485321cbc5fc111f7dad7ee39e69a17</a>
+<blockquote>
+<p>
+ Update PageList processing in the FirstPage/LastPage device<br>
+<br>
+ The intention of the PageList was that pages would be specified in<br>
+ ascending order, but the documentation didn't actually say that<br>
+ explicitly, so update the documentation to make it absolutely clear.<br>
+<br>
+ In addition, by specifying a lower page number at the end, it was<br>
+ possible to cause a buffer overrun, so prevent that here and flag an<br>
+ error to the user so they know.<br>
+<br>
+base/gdevflp.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-07-05 18:04:28 +0100
+</strong>
+<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=18e4b59efeca56ec2ca716559a7b9e0639561428">18e4b59efeca56ec2ca716559a7b9e0639561428</a>
+<blockquote>
+<p>
+ Bug 699379: Fix infinite loop with filenames starting with #.<br>
+<br>
+ The argument handling routines treat lines starting with #<br>
+ as being comments. Unfortunately, the logic for this was failing<br>
+ to recognise EOF as stopping the search for the end of a line.<br>
+<br>
+ Doubly unfortunatately, it was extending this courtesy, intended<br>
+ for lines within @files to command line arguments too. We take<br>
+ steps to avoid that too.<br>
+<br>
+base/gsargs.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-07-05 11:22:41 +0100
+</strong>
+<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f390123f8e34ec149fe1a3366ebb872368a57d7f">f390123f8e34ec149fe1a3366ebb872368a57d7f</a>
+<blockquote>
+<p>
+ Bug 698928: Rework arg_next.<br>
+<br>
+ When I worked on arg_next before, I think I had the wrong idea of<br>
+ what it was doing.<br>
+<br>
+ The idea of arg_next (I thought) was that we'd call it, and get back<br>
+ a pointer to a decoded version of the next argument. Sadly, this<br>
+ wasn't true - it would leave us with an *encoded* version of the<br>
+ argument. Now, for most things this didn't matter, for for encodings<br>
+ like UTF16LE, it certainly did.<br>
+<br>
+ So, largely revert the previous misguided commit to this code, and<br>
+ update arg_next so that it really does return a &quot;decoded&quot; (i.e. always<br>
+ utf-8 encoded) buffer.<br>
+<br>
+ This fixes Bug 698928 where I had an underflow read in a buffer.<br>
+<br>
+base/gsargs.c<br>
+base/gsargs.h<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-07-05 16:38:01 +0100
+</strong>
+<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=62e67ecc475d3648f32d7d8c4459bbabd740ea2b">62e67ecc475d3648f32d7d8c4459bbabd740ea2b</a>
+<blockquote>
+<p>
+ Fix a device subclassing problem with colour mapping procedures<br>
+<br>
+ Bug #699520 &quot;Seg fault with customer device utilising device subclassing&quot;<br>
+<br>
+ When we retrieve colour mapping methods, we need to use the first<br>
+ subclassing device in the chain which does not have a 'default' for<br>
+ the colour mapping methods. This is so that the monochrome palette<br>
+ device in PCL works properly.<br>
+<br>
+ In contrast, if none of the subclassing devices overrides the colour<br>
+ mapping then we want to use the first non-subclassing device's<br>
+ methods and, importantly, that device as well.<br>
+<br>
+base/gxdevcli.h<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-07-03 13:44:28 +0100
+</strong>
+<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2f8082aa9777a7274c463c6375c2f7d01c299251">2f8082aa9777a7274c463c6375c2f7d01c299251</a>
+<blockquote>
+<p>
+ Increase limit on UniqueIDs for fonts<br>
+<br>
+ Bug #699513 &quot;CFF font UniqueID greater then 2^24 - 1 causes error&quot;<br>
+<br>
+ The PDF file contains a font with a UniqueID of 0x7fffff which exceeds<br>
+ the PostScript definition of a font UniqueID (0 -&gt; 2^24 - 1).<br>
+<br>
+ Experimentation shows that no PostScript interpreter that I have access<br>
+ to (other than GS) implements this limit. However, to keep the change<br>
+ conservative, I'm chosen to raise the limit to 2^32-1 to match the CFF<br>
+ specification, rather than eliminate it altogether.<br>
+<br>
+psi/idparam.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-07-03 08:55:43 +0100
+</strong>
+<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3e44dd7a9f112ea5334a4e189ec64f7a16139597">3e44dd7a9f112ea5334a4e189ec64f7a16139597</a>
+<blockquote>
+<p>
+ Remove some obsolete sections from the docs.<br>
+<br>
+ DOS and OS/2 install sections in install.htm<br>
+<br>
+doc/Install.htm<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-06-30 16:10:48 +0100
+</strong>
+<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=dc20112ef13ebdfc6e1ad20ac9ef5462e9145682">dc20112ef13ebdfc6e1ad20ac9ef5462e9145682</a>
+<blockquote>
+<p>
+ Fix a compiler warning<br>
+<br>
+devices/vector/gdevpdfp.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-06-30 14:29:43 +0100
+</strong>
+<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=aba212c73d6f10fe891786a938bb461636563dba">aba212c73d6f10fe891786a938bb461636563dba</a>
+<blockquote>
+<p>
+ pdfwrite - when changing ProcessColorModel, don't just change the name<br>
+<br>
+ Bug 699490 &quot;Broken PDF/X-3 generated&quot;<br>
+<br>
+ The reason that an empty file was generated was due to a mismatch<br>
+ between the underlying device process color model and the ICC profile<br>
+ attached to the device. The profile was a CMYK profile, while the<br>
+ device was set to have 3 components.<br>
+<br>
+ This is due to the fact that setting the ProcessColorModel separately<br>
+ from the ColorConversionStrategy was not actually changing the model,<br>
+ it just changed the name.<br>
+<br>
+ This should, of course, have generated an error and an earlier commit<br>
+ had already addressed that. In this commit, we call the routine which<br>
+ actually switches the colour model, and we also count down the ICC<br>
+ structure attached to the device, and set it to 0. This forces a reload<br>
+ of the ICC profile. That isn't needed for this particular bug but it<br>
+ is needed when OutputICCProfile is not set, because we will otherwise<br>
+ try to use the profile for the prior colour model, which will be<br>
+ incorrect and leaed to errors.<br>
+<br>
+devices/vector/gdevpdfp.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-06-29 14:13:39 -0700
+</strong>
+<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8d415abe6f1e0e3a7e895511e20d99eebad48ada">8d415abe6f1e0e3a7e895511e20d99eebad48ada</a>
+<blockquote>
+<p>
+ Fix rendering issue on tiffscaled devices<br>
+<br>
+ The tiffscaled contone devices have to be able to change their color model<br>
+ to allow a more flexible use of the post render ICC profile with the output<br>
+ intent. Prior to this commit, certain profile combinations would result in<br>
+ mis-rendered results.<br>
+<br>
+ With this fix, if we are wanting to render to a CMYK intermediate<br>
+ output intent but we want the output to be in sRGB then we need to use<br>
+ -sDEVICE=tiffscaled24 -dUsePDFX3Profile -sOutputICCProfile=default_cmyk.icc<br>
+ -sPostRenderProfile=srgb.icc . This should then render to a temporary<br>
+ buffer the is in the OutputIntent color space and then be converted to<br>
+ sRGB. This should look like the result we get when we go out to the<br>
+ tiffscaled32 device. This is in contrast to the command line<br>
+ sDEVICE=tiffscaled24 -dUsePDFX3Profile -sPostRenderProfile=srgb.icc which would<br>
+ end up using the output intent as a proofing profile. The results may be similar<br>
+ but not exact as overprint and spot colors would not appear correctly due to the<br>
+ additive color model during rendering.<br>
+<br>
+base/gsicc.c<br>
+base/gsicc.h<br>
+base/lib.mak<br>
+devices/devs.mak<br>
+devices/gdevtsep.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-06-28 16:44:41 +0100
+</strong>
+<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=da3810ce626a1c5dca856a7bac757bf254761f69">da3810ce626a1c5dca856a7bac757bf254761f69</a>
+<blockquote>
+<p>
+ pdfwrite - create GC desscriptors for JPEG Passthrough stream<br>
+<br>
+ Bug #699427 &quot; Shrinking PDF is causing SIGSEGV&quot;<br>
+<br>
+ Its not absolutely clear that this is the same problem, but I'm<br>
+ reasonably confident. When passing JPEG data through untouched, we<br>
+ copied the stream pointer for the uncompressed data into the device<br>
+ structure (because the image enumerator isn't available at that time)<br>
+ but if the stream should be relocated after the copy is taken, then the<br>
+ old stream might not be valid any more.<br>
+<br>
+ This commit adds a GC descriptor for the copied stream pointer to the<br>
+ PDF device structure. For me this solves the problem, but the nature<br>
+ of these kinds of problems means that *any* change which affects memory<br>
+ layout will affect the execution, so I'm not 100% certain this is the<br>
+ problem.<br>
+<br>
+devices/vector/gdevpdf.c<br>
+devices/vector/gdevpdfx.h<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-06-26 14:52:22 -0700
+</strong>
+<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=250b5e83e923bed9b6d48bf3965f3b38af52286d">250b5e83e923bed9b6d48bf3965f3b38af52286d</a>
+<blockquote>
+<p>
+ Fix errors introduced in previous commit<br>
+<br>
+ The commit f2cf68297e3d63cb927db3c98d317f7ee68e7898<br>
+ resulted in errors with the separation type devices.<br>
+ With these devices, we can simply check if the color<br>
+ model matches the ICC profile since these devices<br>
+ change their number of components. Will likely need<br>
+ to do some testing with these device and different<br>
+ profiles to see what breaks when and make sure we<br>
+ exit gracefully.<br>
+<br>
+base/gsicc_manage.c<br>
+devices/devs.mak<br>
+devices/gdevcmykog.c<br>
+devices/gdevgprf.c<br>
+devices/gdevpsd.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-06-27 13:22:41 +0100
+</strong>
+<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e4a7fc24c051241e4dbd14760a218290769d78a6">e4a7fc24c051241e4dbd14760a218290769d78a6</a>
+<blockquote>
+<p>
+ Fix a typo in a link<br>
+<br>
+doc/API.htm<br>
+doc/C-style.htm<br>
+doc/Commprod.htm<br>
+doc/DLL.htm<br>
+doc/Deprecated.htm<br>
+doc/Develop.htm<br>
+doc/Devices.htm<br>
+doc/Drivers.htm<br>
+doc/Fonts.htm<br>
+doc/History9.htm<br>
+doc/Install.htm<br>
+doc/Language.htm<br>
+doc/Lib.htm<br>
+doc/Make.htm<br>
+doc/News.htm<br>
+doc/Ps-style.htm<br>
+doc/Ps2epsi.htm<br>
+doc/Psfiles.htm<br>
+doc/Readme.htm<br>
+doc/Release.htm<br>
+doc/SavedPages.htm<br>
+doc/Source.htm<br>
+doc/Unix-lpr.htm<br>
+doc/Use.htm<br>
+doc/VectorDevices.htm<br>
+doc/WhatIsGS.htm<br>
+doc/sample_downscale_device.htm<br>
+doc/subclass.htm<br>
+doc/thirdparty.htm<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-06-25 09:44:34 +0100
+</strong>
+<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6a4202691c4317a698fa23c5309ad8974fe2b003">6a4202691c4317a698fa23c5309ad8974fe2b003</a>
+<blockquote>
+<p>
+ Bug 699454: 'improve' pdfwrite guesstimate of glyph bbox<br>
+<br>
+ When estimating the bounding box of a glyph, we were basically only using the<br>
+ FontBBox - which is often bogus (as it is in this case).<br>
+<br>
+ We'll now, additionally, use the advance width of the glyph in that estimate.<br>
+<br>
+ This could possibly result in glyphs being included whose marking operations<br>
+ are outside the current clip, but whose advance width intersects with the<br>
+ current clip. But that would be preferable to (as was happening) a glyph inside<br>
+ the clip being dropped.<br>
+<br>
+ (Using the &quot;real&quot; glyph bbox would require executing the complete charstring,<br>
+ which, obviously, has performance implications)<br>
+<br>
+devices/vector/gdevpdte.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-06-22 11:48:58 -0700
+</strong>
+<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9ae241f271ae2eafc69ca44a0b8b70af17705c0e">9ae241f271ae2eafc69ca44a0b8b70af17705c0e</a>
+<blockquote>
+<p>
+ Fix crash introduced by commit to make lcms thread-safe<br>
+<br>
+ Using a proof profile or even using -dUsePDFX3Profile with<br>
+ a device color model that was different than the output<br>
+ intent caused a crash after commit<br>
+ 9ff6b34e461fcbd4ef27fbb6c5c8a15071fe1370<br>
+<br>
+ Problem was that the intermediate device link was not<br>
+ getting created.<br>
+<br>
+base/gsicc_lcms2mt.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-06-22 10:35:48 -0700
+</strong>
+<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f2cf68297e3d63cb927db3c98d317f7ee68e7898">f2cf68297e3d63cb927db3c98d317f7ee68e7898</a>
+<blockquote>
+<p>
+ Bug 699381 Add error checking for device icc profiles<br>
+<br>
+ Make sure that the various types of profiles that can be set work with<br>
+ the device color model and with each other. Only allow the use of<br>
+ the post render ICC profile when the device supports it.<br>
+<br>
+base/gdevdflt.c<br>
+base/gsdparam.c<br>
+base/gsicc_manage.c<br>
+base/gxdevsop.h<br>
+base/lib.mak<br>
+devices/devs.mak<br>
+devices/gdevtsep.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-06-21 11:56:17 -0700
+</strong>
+<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6b981f05c5dafe5d03e8827cb3b5c1cd879c0644">6b981f05c5dafe5d03e8827cb3b5c1cd879c0644</a>
+<blockquote>
+<p>
+ Fix crash when using PostRenderProfile<br>
+<br>
+ Crash was introduced by commit to make lcms thread-safe<br>
+ 9ff6b34e461fcbd4ef27fbb6c5c8a15071fe1370<br>
+<br>
+base/gsicc_cache.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-06-19 11:28:31 +0100
+</strong>
+<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=da399f89d08f66d8608e83ecf2cd5c33ec45b866">da399f89d08f66d8608e83ecf2cd5c33ec45b866</a>
+<blockquote>
+<p>
+ Don't overwrite filename in the event of an error.<br>
+<br>
+ When we 'wrap' a file to allow thread safe file access for multithreaded clist<br>
+ operation, we replace the original file name with a special 'encoded' file<br>
+ name - we shouldn't do the replacement if the underlying file fails to open<br>
+ since it means the error message shows the encoded file name, rather than the<br>
+ name of the 'real' file.<br>
+<br>
+base/gxclfile.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-06-14 12:47:21 -0700
+</strong>
+<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f92376925f99cd418ce94ab738935eb88013175f">f92376925f99cd418ce94ab738935eb88013175f</a>
+<blockquote>
+<p>
+ Add aarch64:Linux case to tiff config.guess<br>
+<br>
+ Needed for configure on 64-bit Linux on ARM (seen with SUSE 64-bit linux<br>
+ on the Raspberry Pi).<br>
+<br>
+tiff/config/config.guess<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-06-14 12:42:49 -0700
+</strong>
+<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=255fe6272797351f83613e6ca079a903bdabb136">255fe6272797351f83613e6ca079a903bdabb136</a>
+<blockquote>
+<p>
+ Fix typo in lib.mak. Missing sfilter2 in psfilters.dev<br>
+<br>
+ Both entries were $(GLOBJ)sfilter1.$(OBJ) which resulted in s_A85E_template<br>
+ undefined in the link.<br>
+<br>
+base/lib.mak<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-06-14 13:57:30 +0100
+</strong>
+<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fbf2eefa62b8dd4eb1b96aa77b7d4cf6719af5fe">fbf2eefa62b8dd4eb1b96aa77b7d4cf6719af5fe</a>
+<blockquote>
+<p>
+ fix lib.mak for Windows builds<br>
+<br>
+ Commit ca18b9663b10798a2bd800173df3bfbca4a87650 had an extra $(GLOBJ)<br>
+ macro in the build line for psfilters.dev. On Linux this doesn't seem<br>
+ to be a problem, but nmake (Windows build in Visual Studio) throws<br>
+ an error.<br>
+<br>
+ Just remove the extraneous macro.<br>
+<br>
+base/lib.mak<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-06-13 16:27:32 +0100
+</strong>
+<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ca18b9663b10798a2bd800173df3bfbca4a87650">ca18b9663b10798a2bd800173df3bfbca4a87650</a>
+<blockquote>
+<p>
+ Move the PS Level 1 filters into 'base/'<br>
+<br>
+ Oddly, Level 2 filters were already in 'base/', but the Level 1 filters were<br>
+ still (partially) in 'psi/' (but at least one was partially in base/).<br>
+<br>
+ This not only moves the code, but puts both Level 1 and 2 filters into a<br>
+ 'feature' .dev (called psfilters.dev) - on the basis we don't really support<br>
+ building as a Level 1 only interpreter any more.<br>
+<br>
+ It is still up to the interpreter makefile(s) to include the dependency on<br>
+ psfilter.dev to get these built in.<br>
+<br>
+ This is tidier than before, but primarily done so the SubFileDecode filter<br>
+ is available for use by the in-development C based PDF interpreter.<br>
+<br>
+base/lib.mak<br>
+base/sfilter1.c<br>
+psi/int.mak<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-06-12 10:08:09 +0100
+</strong>
+<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e0b4f52ee1904ff3f1cf72d86163321b2f9d6357">e0b4f52ee1904ff3f1cf72d86163321b2f9d6357</a>
+<blockquote>
+<p>
+ Fix PageList when the last page in the file is not included in the list<br>
+<br>
+ It was possible to run off the end of the array of pages if the last<br>
+ page was not included in the list of pages to be printed.<br>
+<br>
+ Also, the trailing '-' syntax (from page 'n' to the end of file) was<br>
+ off by one printing the initial page.<br>
+<br>
+base/gdevflp.c<br>
+base/gdevflp.h<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-06-11 11:31:05 +0100
+</strong>
+<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=bc0b0ff9bd8dbdd91a142b46a0e5f5168c13306d">bc0b0ff9bd8dbdd91a142b46a0e5f5168c13306d</a>
+<blockquote>
+<p>
+ Better fix for bug #699404<br>
+<br>
+ Bug #699404 &quot;Failure with psdcmyk -dGraphicsAlphaBits=4 -dFirstPage=1 -dLastPage=1&quot;<br>
+<br>
+ The commit 3347a19f6fd89fc1b7d9644ff6c4703897501f7e did fix this problem<br>
+ but it left a more serious underlying problem. The devices in the chain<br>
+ weren't being updated to note that the standard subclassing devcies had<br>
+ been installed.<br>
+<br>
+ This could lead to them being installed multiple times, and also to<br>
+ taking the wrong code path and failing to update the device methods<br>
+ when required.<br>
+<br>
+ This commit unwinds the previous one in gdevprn.c and applies a better<br>
+ fix in gdevkrnlsclass.c<br>
+<br>
+base/gdevkrnlsclass.c<br>
+base/gdevprn.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-06-08 14:05:24 +0100
+</strong>
+<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a219c745f5fd3bcf38da40f64c5b7cd053721a16">a219c745f5fd3bcf38da40f64c5b7cd053721a16</a>
+<blockquote>
+<p>
+ Documentation update - PageList<br>
+<br>
+ Update use.htm to make it clear that using PageList will override any<br>
+ values for FirstPage and LastPage.<br>
+<br>
+doc/Use.htm<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-06-07 16:16:08 -0600
+</strong>
+<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=493066fceed538d3c499221aea8e085fba86c827">493066fceed538d3c499221aea8e085fba86c827</a>
+<blockquote>
+<p>
+ Add PCL symbol sets: PC-865 Norway and PC-860 Portugal.<br>
+<br>
+pcl/pl/plsymbol.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-06-06 17:25:00 +0100
+</strong>
+<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3347a19f6fd89fc1b7d9644ff6c4703897501f7e">3347a19f6fd89fc1b7d9644ff6c4703897501f7e</a>
+<blockquote>
+<p>
+ Move installation of standard subclassing devices<br>
+<br>
+ Bug #699404 &quot;Failure with psdcmyk -dGraphicsAlphaBits=4 -dFirstPage=1 -dLastPage=1&quot;<br>
+<br>
+ The installation of the devices in gdev_prn_open() was slightly too<br>
+ early, the procs can still (quite reasonably because this is part of<br>
+ the device installation) be altered by gdev_prn_allocate_memory().<br>
+<br>
+ If we had already subclassed the device, then the procs of the<br>
+ subclassing device (ie firstPage/LastPage) would be altered rather than<br>
+ the real target device's procs. This led to the wrong graphics library<br>
+ call, which produced an error.<br>
+<br>
+ Moving the subclassing later in the installation solves the problem.<br>
+<br>
+base/gdevprn.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-06-05 10:16:26 -0600
+</strong>
+<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=bfbd2a02cd39c799d5d5f2d9850fb0fd06e57b7a">bfbd2a02cd39c799d5d5f2d9850fb0fd06e57b7a</a>
+<blockquote>
+<p>
+ Fix #699390 - text position wrong.<br>
+<br>
+ The PCL current position (CAP) can be in two states: floating or<br>
+ fixed. Floating tracks the origin with margin and orientation changes<br>
+ fixed does not. The CAP is floating until we have printable data or a<br>
+ command that affects the cursor position is received. We were<br>
+ mistakenly resetting the the CAP from fixed to float for orientation<br>
+ changes resulting in incorrect text position.<br>
+<br>
+ Norbert Janssen provided the analysis and code change for this fix.<br>
+<br>
+pcl/pcl/pcpage.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-06-01 17:40:09 +0100
+</strong>
+<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e997c6836d243ab37fe3a5f0d57974af95eb5eac">e997c6836d243ab37fe3a5f0d57974af95eb5eac</a>
+<blockquote>
+<p>
+ pdfwrite - drop UTF16-BE DOCINFO strings when creating PDF/A-1<br>
+<br>
+ Bug #699392 &quot; XMP metadata missing when trying to create PDF/A &quot;<br>
+<br>
+ Its not obvious, but it appears to be impossible to embed UTF-16BE<br>
+ strings in XMP metadata and have them be validated against the same<br>
+ string in the Info dictionary, because of the specified method for<br>
+ comparing such strings.<br>
+<br>
+ PDF/A-2 states that the document information dictionary should be<br>
+ ignored, in contrast to the PDF/A-1 specification which says the<br>
+ XMP and Info dictionary information must be consistent. So this<br>
+ problem can't arise there.<br>
+<br>
+ This commit detects the use of any UTF-16BE string in a DOCINFO<br>
+ pdfmark and use the usual PDFACompatibilityPolicy to decide whether to<br>
+ abort PDF/A-1 production, drop the string or raise an error.<br>
+<br>
+devices/vector/gdevpdfm.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-05-30 15:59:32 +0100
+</strong>
+<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=71de6d0f9c2a48d6e4a69287b2123bf9efd6df88">71de6d0f9c2a48d6e4a69287b2123bf9efd6df88</a>
+<blockquote>
+<p>
+ txtwrite - Increment character index in text enumerator<br>
+<br>
+ Bug #699391 &quot;segfault in txtwrite_process_plain_text()&quot;<br>
+<br>
+ We need to increment the text enumerator character index no matter what<br>
+ kind of operation this is, we had omitted it in the<br>
+ TEXT_FROM_SINGLE_GLYPH case.<br>
+<br>
+devices/vector/gdevtxtw.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-05-28 17:39:55 +0100
+</strong>
+<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7a91a08d9c78b5e37b0d434ffaafa30aa1d680ad">7a91a08d9c78b5e37b0d434ffaafa30aa1d680ad</a>
+<blockquote>
+<p>
+ Bug 699382: Fix UTF-8 encoding screwup.<br>
+<br>
+ Also fix utf8_to_wchar making wchar buffers longer than required.<br>
+<br>
+base/gp_wutf8.c<br>
+base/gsargs.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-05-24 16:37:15 +0100
+</strong>
+<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fa7a350708d393bad28dffff22da4f96ba037001">fa7a350708d393bad28dffff22da4f96ba037001</a>
+<blockquote>
+<p>
+ Ghostscript documentation pages revised to new look and feel<br>
+<br>
+doc/API.htm<br>
+doc/AUTHORS<br>
+doc/C-style.htm<br>
+doc/Changes.htm<br>
+doc/Commprod.htm<br>
+doc/DLL.htm<br>
+doc/Deprecated.htm<br>
+doc/Details.htm<br>
+doc/Details8.htm<br>
+doc/Details9.htm<br>
+doc/Develop.htm<br>
+doc/Devices.htm<br>
+doc/Drivers.htm<br>
+doc/Fonts.htm<br>
+doc/Helpers.htm<br>
+doc/Hershey.htm<br>
+doc/History1.htm<br>
+doc/History2.htm<br>
+doc/History3.htm<br>
+doc/History4.htm<br>
+doc/History5.htm<br>
+doc/History6.htm<br>
+doc/History7.htm<br>
+doc/History8.htm<br>
+doc/History9.htm<br>
+doc/Install.htm<br>
+doc/Issues.htm<br>
+doc/Language.htm<br>
+doc/Lib.htm<br>
+doc/Make.htm<br>
+doc/News.htm<br>
+doc/Projects.htm<br>
+doc/Ps-style.htm<br>
+doc/Ps2epsi.htm<br>
+doc/Psfiles.htm<br>
+doc/Readme.htm<br>
+doc/Release.htm<br>
+doc/SavedPages.htm<br>
+doc/Source.htm<br>
+doc/Unix-lpr.htm<br>
+doc/Use.htm<br>
+doc/VectorDevices.htm<br>
+doc/WhatIsGS.htm<br>
+doc/gs-style.css<br>
+doc/gs.css<br>
+doc/images/.DS_Store<br>
+doc/images/Artifex_logo.png<br>
+doc/images/favicon.png<br>
+doc/images/ghostscript_logo.png<br>
+doc/images/hamburger-light.png<br>
+doc/images/x-light.png<br>
+doc/index.js<br>
+doc/sample_downscale_device.htm<br>
+doc/style.css<br>
+doc/subclass.htm<br>
+doc/thirdparty.htm<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-05-24 09:21:17 +0100
+</strong>
+<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1eab394d3715ac37eca4ee3d4b139520166f37f4">1eab394d3715ac37eca4ee3d4b139520166f37f4</a>
+<blockquote>
+<p>
+ Improve FirstPage/LastPage image data handling<br>
+<br>
+ commit e92f7cbadec35ced4e38d2be9bf13fe4f362aa59 had the right idea but<br>
+ erroneous implementation. We can't simply cast the image enumerator,<br>
+ because we didn't allocate the enumerator that way.<br>
+<br>
+ Instead, add the expected height and tracking variable to the individual<br>
+ enumerator.<br>
+<br>
+ Implement for object filtering device as well.<br>
+<br>
+base/gdevflp.c<br>
+base/gdevoflt.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-05-23 15:57:16 +0100
+</strong>
+<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=59dce27871a39a9f161aaaf0e852dbd05ba009fe">59dce27871a39a9f161aaaf0e852dbd05ba009fe</a>
+<blockquote>
+<p>
+ PDF interpreter - fix illegal CIDSystemInfo dictionaries<br>
+<br>
+ Bug #699294 &quot; Ghostscript giving errors for attached pdfs and generating blank tiffs&quot;<br>
+<br>
+ The supplied example file has several CIDFonts embedded which have<br>
+ illegal CIDSystemInfo dictionaries; they are missing the required<br>
+ Registry and Ordering entries.<br>
+<br>
+ A long time ago we discarded the CIDSystemInfo from the CIDFont and<br>
+ created a dummy one, which is why the reporter thinks this 'used to<br>
+ work'. It didn't. Discarding the information caused problems with the<br>
+ pdfwrite output.<br>
+<br>
+ In this case we simply manufacture the missing data. Its wrong, but it<br>
+ allows the file to proceed to completion. Naturally we emit a warning<br>
+ so that users know their file is garbage.<br>
+<br>
+Resource/Init/pdf_font.ps<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-05-23 09:14:07 +0100
+</strong>
+<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e92f7cbadec35ced4e38d2be9bf13fe4f362aa59">e92f7cbadec35ced4e38d2be9bf13fe4f362aa59</a>
+<blockquote>
+<p>
+ First/Last page - Fix image data handling with proc data source<br>
+<br>
+ Bug #699215 &quot;Subclassing device leads to infinite(?) loop&quot;<br>
+<br>
+ When processing images, its acceptable for the subclassed device to<br>
+ return 0 (need more data) in response to image_plane_data, if the<br>
+ source is a file, because the file will reach EOF and the code will<br>
+ properly terminate.<br>
+<br>
+ For procedural (or string) data sources this isn't true. The code needs<br>
+ to keep track of the number of rows of image data received, and return<br>
+ 1 (completed) when we have received enough data.<br>
+<br>
+ Fixed the object filtering device at the same time.<br>
+<br>
+base/gdevflp.c<br>
+base/gdevoflt.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-05-22 14:47:54 +0100
+</strong>
+<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b61071c9411c3f6aa0dd594da2c5a20ff4ecd914">b61071c9411c3f6aa0dd594da2c5a20ff4ecd914</a>
+<blockquote>
+<p>
+ Replace EOI marker in JPEG passthrough<br>
+<br>
+ Bug #699216 &quot; JPEG passthrough appears to truncate JPEGs in some cases&quot;<br>
+<br>
+ The IJG JPEG implementation consumes the EOI marker before the JPEG<br>
+ passthrough code gets to see it (in general). Most PDF consumers don't<br>
+ care, but some seem to, so when we terminate the DCT decompression<br>
+ send the EOI marker to the passthrough code.<br>
+<br>
+base/sdctd.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-05-22 14:04:31 +0100
+</strong>
+<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4a288cb8678517c578b336b3d26e5c4115906624">4a288cb8678517c578b336b3d26e5c4115906624</a>
+<blockquote>
+<p>
+ Fix conversion from PDF time to XMP time for pdfwrite<br>
+<br>
+ Bug #699182 &quot; Invalid XMP metadata and possibly invalid memory access for dates without timezone in pdfmark&quot;<br>
+<br>
+ Two different problems; in the first case a '&gt;' should be '&gt;=' so that<br>
+ we properly identify an empty string.<br>
+<br>
+ Then when converting the string, there was a different off-by-one error<br>
+ in the buffer index. Also corrected a comment while passing.<br>
+<br>
+devices/vector/gdevpdfe.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-05-22 10:51:46 +0100
+</strong>
+<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=16ad4cc70918da40f62a919e11187dfb72f4ff63">16ad4cc70918da40f62a919e11187dfb72f4ff63</a>
+<blockquote>
+<p>
+ Prevent use of CID 0 in a PDF/A output file.<br>
+<br>
+ Bug #699375 &quot;PDF/A 1b / 2b Validation fails after conversion with Ghostscript on some files&quot;<br>
+<br>
+ The input file(s) use CID 0 (which is defined as the /.notdef glyph)<br>
+ which is illegal in PDF/A files.<br>
+<br>
+ 'Fixing' this would require us to alter the CID, change the CMap and<br>
+ the ToUnicode CMap, and runs the obvious risk of the CID we use as a<br>
+ replacement being used later in the document. We could avoid this by<br>
+ scanning for 'holes' in the CMap, but even that potentially leaves us<br>
+ with a problem if there are no empty entries in the CMap.<br>
+<br>
+ Since we can't guarantee fixing the problem, a partial fix would be a<br>
+ great deal of coding, would almost certainly introduce a bug tail and<br>
+ still wouldn't guarantee a compliant result, don't try. Instead if we<br>
+ encounter this condition abort PDF/A output, or throw an error if the<br>
+ PDFACompatibilityPolicy is set that way.<br>
+<br>
+devices/vector/gdevpdtc.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-05-17 14:30:40 +0100
+</strong>
+<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=48e4565e967eae091b97a9037e77016d8d99f3ce">48e4565e967eae091b97a9037e77016d8d99f3ce</a>
+<blockquote>
+<p>
+ Bug 699329: add display device to default Unix build.<br>
+<br>
+ Previously it was only included in the .so build (it doesn't really make sense<br>
+ in a monolithic exe build). But since we now have a &quot;supported&quot; static library<br>
+ build, it makes sense to include it.<br>
+<br>
+configure.ac<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-05-17 07:35:02 +0100
+</strong>
+<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=891ea7d2813edaa3c7c874a4053afdda128e8a10">891ea7d2813edaa3c7c874a4053afdda128e8a10</a>
+<blockquote>
+<p>
+ Fix for small glyph distortion<br>
+<br>
+ Glyphs with very few pixels (i.e. lower case &quot;i&quot; in 9pt text rendered at 72dpi)<br>
+ we being distorted due to the specific rules applied by Freetype's dropout<br>
+ compensation. This isn't a full solution but resolves the change in behaviour<br>
+ between 2.7.x and 2.9.x (the change was due to different rounding being<br>
+ applied).<br>
+<br>
+ This fix is from upstream:<br>
+ http://git.savannah.gnu.org/cgit/freetype/freetype2.git/commit/?id=f1458d2e44d8<br>
+<br>
+ So should be in future Freetype releases, and not need re-applied here.<br>
+<br>
+freetype/src/base/ftobjs.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-04-03 15:49:48 +0100
+</strong>
+<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9cb169b6b260f650aac2c3c7ed7af0f345ee0707">9cb169b6b260f650aac2c3c7ed7af0f345ee0707</a>
+<blockquote>
+<p>
+ Work around a behaviour change in freetype &gt; 2.8<br>
+<br>
+ Freetype will throw an error when we try to retrieve the glyph if the x/y<br>
+ advance values are too big to fit in a 16.16 fixed point value.<br>
+<br>
+ Since we have no need of those values, set them to zero, and avoid the error.<br>
+<br>
+ Bring freetype up to 2.9.1<br>
+<br>
+ Plus the gs makefile changes to support the new version.<br>
+<br>
+ Reapply &quot;Work around a change in the zlib API for 1.2.11&quot;<br>
+<br>
+ for Freetype<br>
+ commit: 08482c582115a1396d0fd9186011008f889a61c5<br>
+<br>
+base/fapi_ft.c<br>
+base/freetype.mak<br>
+freetype/CMakeLists.txt<br>
+freetype/ChangeLog<br>
+freetype/ChangeLog.20<br>
+freetype/ChangeLog.21<br>
+freetype/ChangeLog.22<br>
+freetype/ChangeLog.23<br>
+freetype/ChangeLog.24<br>
+freetype/ChangeLog.25<br>
+freetype/ChangeLog.26<br>
+freetype/ChangeLog.27<br>
+freetype/ChangeLog.28<br>
+freetype/Jamfile<br>
+freetype/Jamrules<br>
+freetype/Makefile<br>
+freetype/README<br>
+freetype/README.git<br>
+freetype/autogen.sh<br>
+freetype/builds/amiga/README<br>
+freetype/builds/amiga/include/config/ftconfig.h<br>
+freetype/builds/amiga/include/config/ftmodule.h<br>
+freetype/builds/amiga/makefile<br>
+freetype/builds/amiga/makefile.os4<br>
+freetype/builds/amiga/smakefile<br>
+freetype/builds/amiga/src/base/ftdebug.c<br>
+freetype/builds/amiga/src/base/ftsystem.c<br>
+freetype/builds/ansi/ansi-def.mk<br>
+freetype/builds/ansi/ansi.mk<br>
+freetype/builds/beos/beos-def.mk<br>
+freetype/builds/beos/beos.mk<br>
+freetype/builds/beos/detect.mk<br>
+freetype/builds/cmake/FindHarfBuzz.cmake<br>
+freetype/builds/cmake/iOS.cmake<br>
+freetype/builds/cmake/testbuild.sh<br>
+freetype/builds/compiler/ansi-cc.mk<br>
+freetype/builds/compiler/bcc-dev.mk<br>
+freetype/builds/compiler/bcc.mk<br>
+freetype/builds/compiler/emx.mk<br>
+freetype/builds/compiler/gcc-dev.mk<br>
+freetype/builds/compiler/gcc.mk<br>
+freetype/builds/compiler/intelc.mk<br>
+freetype/builds/compiler/unix-lcc.mk<br>
+freetype/builds/compiler/visualage.mk<br>
+freetype/builds/compiler/visualc.mk<br>
+freetype/builds/compiler/watcom.mk<br>
+freetype/builds/compiler/win-lcc.mk<br>
+freetype/builds/detect.mk<br>
+freetype/builds/dos/detect.mk<br>
+freetype/builds/dos/dos-def.mk<br>
+freetype/builds/dos/dos-emx.mk<br>
+freetype/builds/dos/dos-gcc.mk<br>
+freetype/builds/dos/dos-wat.mk<br>
+freetype/builds/exports.mk<br>
+freetype/builds/freetype.mk<br>
+freetype/builds/link_dos.mk<br>
+freetype/builds/link_std.mk<br>
+freetype/builds/mac/FreeType.m68k_cfm.make.txt<br>
+freetype/builds/mac/FreeType.m68k_far.make.txt<br>
+freetype/builds/mac/FreeType.ppc_carbon.make.txt<br>
+freetype/builds/mac/FreeType.ppc_classic.make.txt<br>
+freetype/builds/mac/ftmac.c<br>
+freetype/builds/modules.mk<br>
+freetype/builds/newline<br>
+freetype/builds/os2/detect.mk<br>
+freetype/builds/os2/os2-def.mk<br>
+freetype/builds/os2/os2-dev.mk<br>
+freetype/builds/os2/os2-gcc.mk<br>
+freetype/builds/symbian/bld.inf<br>
+freetype/builds/symbian/freetype.mmp<br>
+freetype/builds/toplevel.mk<br>
+freetype/builds/unix/aclocal.m4<br>
+freetype/builds/unix/config.guess<br>
+freetype/builds/unix/config.sub<br>
+freetype/builds/unix/configure<br>
+freetype/builds/unix/configure.ac<br>
+freetype/builds/unix/configure.raw<br>
+freetype/builds/unix/detect.mk<br>
+freetype/builds/unix/freetype-config.in<br>
+freetype/builds/unix/freetype2.in<br>
+freetype/builds/unix/freetype2.m4<br>
+freetype/builds/unix/ft-munmap.m4<br>
+freetype/builds/unix/ftconfig.in<br>
+freetype/builds/unix/ftsystem.c<br>
+freetype/builds/unix/install.mk<br>
+freetype/builds/unix/pkg.m4<br>
+freetype/builds/unix/unix-cc.in<br>
+freetype/builds/unix/unix-def.in<br>
+freetype/builds/unix/unix-dev.mk<br>
+freetype/builds/unix/unix-lcc.mk<br>
+freetype/builds/unix/unix.mk<br>
+freetype/builds/unix/unixddef.mk<br>
+freetype/builds/vms/ftconfig.h<br>
+freetype/builds/vms/ftsystem.c<br>
+freetype/builds/wince/ftdebug.c<br>
+freetype/builds/wince/vc2005-ce/freetype.vcproj<br>
+freetype/builds/wince/vc2005-ce/index.html<br>
+freetype/builds/wince/vc2008-ce/freetype.vcproj<br>
+freetype/builds/wince/vc2008-ce/index.html<br>
+freetype/builds/windows/detect.mk<br>
+freetype/builds/windows/ftdebug.c<br>
+freetype/builds/windows/vc2005/freetype.vcproj<br>
+freetype/builds/windows/vc2005/index.html<br>
+freetype/builds/windows/vc2008/freetype.vcproj<br>
+freetype/builds/windows/vc2008/index.html<br>
+freetype/builds/windows/vc2010/freetype.sln<br>
+freetype/builds/windows/vc2010/freetype.vcxproj<br>
+freetype/builds/windows/vc2010/freetype.vcxproj.filters<br>
+freetype/builds/windows/vc2010/index.html<br>
+freetype/builds/windows/visualc/freetype.dsp<br>
+freetype/builds/windows/visualc/freetype.vcproj<br>
+freetype/builds/windows/visualc/index.html<br>
+freetype/builds/windows/visualce/freetype.dsp<br>
+freetype/builds/windows/visualce/freetype.vcproj<br>
+freetype/builds/windows/visualce/index.html<br>
+freetype/builds/windows/w32-bcc.mk<br>
+freetype/builds/windows/w32-bccd.mk<br>
+freetype/builds/windows/w32-dev.mk<br>
+freetype/builds/windows/w32-gcc.mk<br>
+freetype/builds/windows/w32-icc.mk<br>
+freetype/builds/windows/w32-intl.mk<br>
+freetype/builds/windows/w32-lcc.mk<br>
+freetype/builds/windows/w32-mingw32.mk<br>
+freetype/builds/windows/w32-vcc.mk<br>
+freetype/builds/windows/w32-wat.mk<br>
+freetype/builds/windows/win32-def.mk<br>
+freetype/configure<br>
+freetype/devel/ft2build.h<br>
+freetype/devel/ftoption.h<br>
+freetype/docs/CHANGES<br>
+freetype/docs/CUSTOMIZE<br>
+freetype/docs/DEBUG<br>
+freetype/docs/FTL.TXT<br>
+freetype/docs/INSTALL<br>
+freetype/docs/INSTALL.ANY<br>
+freetype/docs/INSTALL.CROSS<br>
+freetype/docs/INSTALL.GNU<br>
+freetype/docs/INSTALL.MAC<br>
+freetype/docs/INSTALL.UNIX<br>
+freetype/docs/INSTALL.VMS<br>
+freetype/docs/MAKEPP<br>
+freetype/docs/TODO<br>
+freetype/docs/VERSIONS.TXT<br>
+freetype/docs/formats.txt<br>
+freetype/docs/freetype-config.1<br>
+freetype/docs/raster.txt<br>
+freetype/docs/reference/ft2-auto_hinter.html<br>
+freetype/docs/reference/ft2-base_interface.html<br>
+freetype/docs/reference/ft2-basic_types.html<br>
+freetype/docs/reference/ft2-bdf_fonts.html<br>
+freetype/docs/reference/ft2-bitmap_handling.html<br>
+freetype/docs/reference/ft2-bzip2.html<br>
+freetype/docs/reference/ft2-cache_subsystem.html<br>
+freetype/docs/reference/ft2-cff_driver.html<br>
+freetype/docs/reference/ft2-cid_fonts.html<br>
+freetype/docs/reference/ft2-computations.html<br>
+freetype/docs/reference/ft2-error_code_values.html<br>
+freetype/docs/reference/ft2-error_enumerations.html<br>
+freetype/docs/reference/ft2-font_formats.html<br>
+freetype/docs/reference/ft2-gasp_table.html<br>
+freetype/docs/reference/ft2-glyph_management.html<br>
+freetype/docs/reference/ft2-glyph_stroker.html<br>
+freetype/docs/reference/ft2-glyph_variants.html<br>
+freetype/docs/reference/ft2-gx_validation.html<br>
+freetype/docs/reference/ft2-gzip.html<br>
+freetype/docs/reference/ft2-header_file_macros.html<br>
+freetype/docs/reference/ft2-header_inclusion.html<br>
+freetype/docs/reference/ft2-incremental.html<br>
+freetype/docs/reference/ft2-index.html<br>
+freetype/docs/reference/ft2-lcd_filtering.html<br>
+freetype/docs/reference/ft2-list_processing.html<br>
+freetype/docs/reference/ft2-lzw.html<br>
+freetype/docs/reference/ft2-mac_specific.html<br>
+freetype/docs/reference/ft2-module_management.html<br>
+freetype/docs/reference/ft2-multiple_masters.html<br>
+freetype/docs/reference/ft2-ot_validation.html<br>
+freetype/docs/reference/ft2-outline_processing.html<br>
+freetype/docs/reference/ft2-parameter_tags.html<br>
+freetype/docs/reference/ft2-pcf_driver.html<br>
+freetype/docs/reference/ft2-pfr_fonts.html<br>
+freetype/docs/reference/ft2-properties.html<br>
+freetype/docs/reference/ft2-quick_advance.html<br>
+freetype/docs/reference/ft2-raster.html<br>
+freetype/docs/reference/ft2-sfnt_names.html<br>
+freetype/docs/reference/ft2-sizes_management.html<br>
+freetype/docs/reference/ft2-system_interface.html<br>
+freetype/docs/reference/ft2-t1_cid_driver.html<br>
+freetype/docs/reference/ft2-toc.html<br>
+freetype/docs/reference/ft2-truetype_engine.html<br>
+freetype/docs/reference/ft2-truetype_tables.html<br>
+freetype/docs/reference/ft2-tt_driver.html<br>
+freetype/docs/reference/ft2-type1_tables.html<br>
+freetype/docs/reference/ft2-user_allocation.html<br>
+freetype/docs/reference/ft2-version.html<br>
+freetype/docs/reference/ft2-winfnt_fonts.html<br>
+freetype/docs/release<br>
+freetype/include/freetype/config/ftconfig.h<br>
+freetype/include/freetype/config/ftheader.h<br>
+freetype/include/freetype/config/ftoption.h<br>
+freetype/include/freetype/config/ftstdlib.h<br>
+freetype/include/freetype/freetype.h<br>
+freetype/include/freetype/ftadvanc.h<br>
+freetype/include/freetype/ftautoh.h<br>
+freetype/include/freetype/ftbbox.h<br>
+freetype/include/freetype/ftbdf.h<br>
+freetype/include/freetype/ftbitmap.h<br>
+freetype/include/freetype/ftbzip2.h<br>
+freetype/include/freetype/ftcache.h<br>
+freetype/include/freetype/ftcffdrv.h<br>
+freetype/include/freetype/ftchapters.h<br>
+freetype/include/freetype/ftcid.h<br>
+freetype/include/freetype/ftdriver.h<br>
+freetype/include/freetype/fterrdef.h<br>
+freetype/include/freetype/fterrors.h<br>
+freetype/include/freetype/ftfntfmt.h<br>
+freetype/include/freetype/ftgasp.h<br>
+freetype/include/freetype/ftglyph.h<br>
+freetype/include/freetype/ftgxval.h<br>
+freetype/include/freetype/ftgzip.h<br>
+freetype/include/freetype/ftimage.h<br>
+freetype/include/freetype/ftincrem.h<br>
+freetype/include/freetype/ftlcdfil.h<br>
+freetype/include/freetype/ftlist.h<br>
+freetype/include/freetype/ftlzw.h<br>
+freetype/include/freetype/ftmac.h<br>
+freetype/include/freetype/ftmm.h<br>
+freetype/include/freetype/ftmodapi.h<br>
+freetype/include/freetype/ftmoderr.h<br>
+freetype/include/freetype/ftotval.h<br>
+freetype/include/freetype/ftoutln.h<br>
+freetype/include/freetype/ftparams.h<br>
+freetype/include/freetype/ftpfr.h<br>
+freetype/include/freetype/ftrender.h<br>
+freetype/include/freetype/ftsizes.h<br>
+freetype/include/freetype/ftsnames.h<br>
+freetype/include/freetype/ftstroke.h<br>
+freetype/include/freetype/ftsynth.h<br>
+freetype/include/freetype/ftsystem.h<br>
+freetype/include/freetype/fttrigon.h<br>
+freetype/include/freetype/ftttdrv.h<br>
+freetype/include/freetype/fttypes.h<br>
+freetype/include/freetype/ftwinfnt.h<br>
+freetype/include/freetype/internal/autohint.h<br>
+freetype/include/freetype/internal/cffotypes.h<br>
+freetype/include/freetype/internal/cfftypes.h<br>
+freetype/include/freetype/internal/ftcalc.h<br>
+freetype/include/freetype/internal/ftdebug.h<br>
+freetype/include/freetype/internal/ftdrv.h<br>
+freetype/include/freetype/internal/ftgloadr.h<br>
+freetype/include/freetype/internal/ftmemory.h<br>
+freetype/include/freetype/internal/ftobjs.h<br>
+freetype/include/freetype/internal/ftpic.h<br>
+freetype/include/freetype/internal/ftpsprop.h<br>
+freetype/include/freetype/internal/ftrfork.h<br>
+freetype/include/freetype/internal/ftserv.h<br>
+freetype/include/freetype/internal/ftstream.h<br>
+freetype/include/freetype/internal/fttrace.h<br>
+freetype/include/freetype/internal/ftvalid.h<br>
+freetype/include/freetype/internal/internal.h<br>
+freetype/include/freetype/internal/psaux.h<br>
+freetype/include/freetype/internal/pshints.h<br>
+freetype/include/freetype/internal/services/svbdf.h<br>
+freetype/include/freetype/internal/services/svcfftl.h<br>
+freetype/include/freetype/internal/services/svcid.h<br>
+freetype/include/freetype/internal/services/svfntfmt.h<br>
+freetype/include/freetype/internal/services/svgldict.h<br>
+freetype/include/freetype/internal/services/svgxval.h<br>
+freetype/include/freetype/internal/services/svkern.h<br>
+freetype/include/freetype/internal/services/svmetric.h<br>
+freetype/include/freetype/internal/services/svmm.h<br>
+freetype/include/freetype/internal/services/svotval.h<br>
+freetype/include/freetype/internal/services/svpfr.h<br>
+freetype/include/freetype/internal/services/svpostnm.h<br>
+freetype/include/freetype/internal/services/svprop.h<br>
+freetype/include/freetype/internal/services/svpscmap.h<br>
+freetype/include/freetype/internal/services/svpsinfo.h<br>
+freetype/include/freetype/internal/services/svsfnt.h<br>
+freetype/include/freetype/internal/services/svttcmap.h<br>
+freetype/include/freetype/internal/services/svtteng.h<br>
+freetype/include/freetype/internal/services/svttglyf.h<br>
+freetype/include/freetype/internal/services/svwinfnt.h<br>
+freetype/include/freetype/internal/sfnt.h<br>
+freetype/include/freetype/internal/t1types.h<br>
+freetype/include/freetype/internal/tttypes.h<br>
+freetype/include/freetype/t1tables.h<br>
+freetype/include/freetype/ttnameid.h<br>
+freetype/include/freetype/tttables.h<br>
+freetype/include/freetype/tttags.h<br>
+freetype/include/freetype/ttunpat.h<br>
+freetype/include/ft2build.h<br>
+freetype/modules.cfg<br>
+freetype/src/Jamfile<br>
+freetype/src/autofit/Jamfile<br>
+freetype/src/autofit/afangles.c<br>
+freetype/src/autofit/afblue.c<br>
+freetype/src/autofit/afblue.cin<br>
+freetype/src/autofit/afblue.dat<br>
+freetype/src/autofit/afblue.h<br>
+freetype/src/autofit/afblue.hin<br>
+freetype/src/autofit/afcjk.c<br>
+freetype/src/autofit/afcjk.h<br>
+freetype/src/autofit/afcover.h<br>
+freetype/src/autofit/afdummy.c<br>
+freetype/src/autofit/afdummy.h<br>
+freetype/src/autofit/aferrors.h<br>
+freetype/src/autofit/afglobal.c<br>
+freetype/src/autofit/afglobal.h<br>
+freetype/src/autofit/afhints.c<br>
+freetype/src/autofit/afhints.h<br>
+freetype/src/autofit/afindic.c<br>
+freetype/src/autofit/afindic.h<br>
+freetype/src/autofit/aflatin.c<br>
+freetype/src/autofit/aflatin.h<br>
+freetype/src/autofit/aflatin2.c<br>
+freetype/src/autofit/aflatin2.h<br>
+freetype/src/autofit/afloader.c<br>
+freetype/src/autofit/afloader.h<br>
+freetype/src/autofit/afmodule.c<br>
+freetype/src/autofit/afmodule.h<br>
+freetype/src/autofit/afpic.c<br>
+freetype/src/autofit/afpic.h<br>
+freetype/src/autofit/afranges.c<br>
+freetype/src/autofit/afranges.h<br>
+freetype/src/autofit/afscript.h<br>
+freetype/src/autofit/afshaper.c<br>
+freetype/src/autofit/afshaper.h<br>
+freetype/src/autofit/afstyles.h<br>
+freetype/src/autofit/aftypes.h<br>
+freetype/src/autofit/afwarp.c<br>
+freetype/src/autofit/afwarp.h<br>
+freetype/src/autofit/afwrtsys.h<br>
+freetype/src/autofit/autofit.c<br>
+freetype/src/autofit/module.mk<br>
+freetype/src/autofit/rules.mk<br>
+freetype/src/base/Jamfile<br>
+freetype/src/base/basepic.c<br>
+freetype/src/base/basepic.h<br>
+freetype/src/base/ftadvanc.c<br>
+freetype/src/base/ftapi.c<br>
+freetype/src/base/ftbase.c<br>
+freetype/src/base/ftbase.h<br>
+freetype/src/base/ftbbox.c<br>
+freetype/src/base/ftbdf.c<br>
+freetype/src/base/ftbitmap.c<br>
+freetype/src/base/ftcalc.c<br>
+freetype/src/base/ftcid.c<br>
+freetype/src/base/ftdbgmem.c<br>
+freetype/src/base/ftdebug.c<br>
+freetype/src/base/ftfntfmt.c<br>
+freetype/src/base/ftfstype.c<br>
+freetype/src/base/ftgasp.c<br>
+freetype/src/base/ftgloadr.c<br>
+freetype/src/base/ftglyph.c<br>
+freetype/src/base/ftgxval.c<br>
+freetype/src/base/ftinit.c<br>
+freetype/src/base/ftlcdfil.c<br>
+freetype/src/base/ftmac.c<br>
+freetype/src/base/ftmm.c<br>
+freetype/src/base/ftobjs.c<br>
+freetype/src/base/ftotval.c<br>
+freetype/src/base/ftoutln.c<br>
+freetype/src/base/ftpatent.c<br>
+freetype/src/base/ftpfr.c<br>
+freetype/src/base/ftpic.c<br>
+freetype/src/base/ftpsprop.c<br>
+freetype/src/base/ftrfork.c<br>
+freetype/src/base/ftsnames.c<br>
+freetype/src/base/ftstream.c<br>
+freetype/src/base/ftstroke.c<br>
+freetype/src/base/ftsynth.c<br>
+freetype/src/base/ftsystem.c<br>
+freetype/src/base/fttrigon.c<br>
+freetype/src/base/fttype1.c<br>
+freetype/src/base/ftutil.c<br>
+freetype/src/base/ftver.rc<br>
+freetype/src/base/ftwinfnt.c<br>
+freetype/src/base/rules.mk<br>
+freetype/src/bdf/Jamfile<br>
+freetype/src/bdf/README<br>
+freetype/src/bdf/bdf.c<br>
+freetype/src/bdf/bdfdrivr.c<br>
+freetype/src/bdf/bdflib.c<br>
+freetype/src/bzip2/Jamfile<br>
+freetype/src/bzip2/ftbzip2.c<br>
+freetype/src/bzip2/rules.mk<br>
+freetype/src/cache/Jamfile<br>
+freetype/src/cache/ftcache.c<br>
+freetype/src/cache/ftcbasic.c<br>
+freetype/src/cache/ftccache.c<br>
+freetype/src/cache/ftccache.h<br>
+freetype/src/cache/ftccback.h<br>
+freetype/src/cache/ftccmap.c<br>
+freetype/src/cache/ftcerror.h<br>
+freetype/src/cache/ftcglyph.c<br>
+freetype/src/cache/ftcglyph.h<br>
+freetype/src/cache/ftcimage.c<br>
+freetype/src/cache/ftcimage.h<br>
+freetype/src/cache/ftcmanag.c<br>
+freetype/src/cache/ftcmanag.h<br>
+freetype/src/cache/ftcmru.c<br>
+freetype/src/cache/ftcmru.h<br>
+freetype/src/cache/ftcsbits.c<br>
+freetype/src/cache/ftcsbits.h<br>
+freetype/src/cache/rules.mk<br>
+freetype/src/cff/Jamfile<br>
+freetype/src/cff/cf2intrp.c<br>
+freetype/src/cff/cff.c<br>
+freetype/src/cff/cffcmap.c<br>
+freetype/src/cff/cffcmap.h<br>
+freetype/src/cff/cffdrivr.c<br>
+freetype/src/cff/cffdrivr.h<br>
+freetype/src/cff/cfferrs.h<br>
+freetype/src/cff/cffgload.c<br>
+freetype/src/cff/cffgload.h<br>
+freetype/src/cff/cffload.c<br>
+freetype/src/cff/cffload.h<br>
+freetype/src/cff/cffobjs.c<br>
+freetype/src/cff/cffobjs.h<br>
+freetype/src/cff/cffparse.c<br>
+freetype/src/cff/cffparse.h<br>
+freetype/src/cff/cffpic.c<br>
+freetype/src/cff/cffpic.h<br>
+freetype/src/cff/cfftoken.h<br>
+freetype/src/cff/module.mk<br>
+freetype/src/cff/rules.mk<br>
+freetype/src/cid/Jamfile<br>
+freetype/src/cid/ciderrs.h<br>
+freetype/src/cid/cidgload.c<br>
+freetype/src/cid/cidgload.h<br>
+freetype/src/cid/cidload.c<br>
+freetype/src/cid/cidload.h<br>
+freetype/src/cid/cidobjs.c<br>
+freetype/src/cid/cidobjs.h<br>
+freetype/src/cid/cidparse.c<br>
+freetype/src/cid/cidparse.h<br>
+freetype/src/cid/cidriver.c<br>
+freetype/src/cid/cidriver.h<br>
+freetype/src/cid/cidtoken.h<br>
+freetype/src/cid/module.mk<br>
+freetype/src/cid/rules.mk<br>
+freetype/src/cid/type1cid.c<br>
+freetype/src/gxvalid/Jamfile<br>
+freetype/src/gxvalid/README<br>
+freetype/src/gxvalid/gxvalid.c<br>
+freetype/src/gxvalid/gxvalid.h<br>
+freetype/src/gxvalid/gxvbsln.c<br>
+freetype/src/gxvalid/gxvcommn.c<br>
+freetype/src/gxvalid/gxvcommn.h<br>
+freetype/src/gxvalid/gxverror.h<br>
+freetype/src/gxvalid/gxvfeat.c<br>
+freetype/src/gxvalid/gxvfeat.h<br>
+freetype/src/gxvalid/gxvfgen.c<br>
+freetype/src/gxvalid/gxvjust.c<br>
+freetype/src/gxvalid/gxvkern.c<br>
+freetype/src/gxvalid/gxvlcar.c<br>
+freetype/src/gxvalid/gxvmod.c<br>
+freetype/src/gxvalid/gxvmod.h<br>
+freetype/src/gxvalid/gxvmort.c<br>
+freetype/src/gxvalid/gxvmort.h<br>
+freetype/src/gxvalid/gxvmort0.c<br>
+freetype/src/gxvalid/gxvmort1.c<br>
+freetype/src/gxvalid/gxvmort2.c<br>
+freetype/src/gxvalid/gxvmort4.c<br>
+freetype/src/gxvalid/gxvmort5.c<br>
+freetype/src/gxvalid/gxvmorx.c<br>
+freetype/src/gxvalid/gxvmorx.h<br>
+freetype/src/gxvalid/gxvmorx0.c<br>
+freetype/src/gxvalid/gxvmorx1.c<br>
+freetype/src/gxvalid/gxvmorx2.c<br>
+freetype/src/gxvalid/gxvmorx4.c<br>
+freetype/src/gxvalid/gxvmorx5.c<br>
+freetype/src/gxvalid/gxvopbd.c<br>
+freetype/src/gxvalid/gxvprop.c<br>
+freetype/src/gxvalid/gxvtrak.c<br>
+freetype/src/gxvalid/module.mk<br>
+freetype/src/gxvalid/rules.mk<br>
+freetype/src/gzip/Jamfile<br>
+freetype/src/gzip/ftgzip.c<br>
+freetype/src/gzip/ftzconf.h<br>
+freetype/src/gzip/rules.mk<br>
+freetype/src/gzip/zlib.h<br>
+freetype/src/lzw/Jamfile<br>
+freetype/src/lzw/ftlzw.c<br>
+freetype/src/lzw/ftzopen.c<br>
+freetype/src/lzw/ftzopen.h<br>
+freetype/src/lzw/rules.mk<br>
+freetype/src/otvalid/Jamfile<br>
+freetype/src/otvalid/module.mk<br>
+freetype/src/otvalid/otvalid.c<br>
+freetype/src/otvalid/otvalid.h<br>
+freetype/src/otvalid/otvbase.c<br>
+freetype/src/otvalid/otvcommn.c<br>
+freetype/src/otvalid/otvcommn.h<br>
+freetype/src/otvalid/otverror.h<br>
+freetype/src/otvalid/otvgdef.c<br>
+freetype/src/otvalid/otvgpos.c<br>
+freetype/src/otvalid/otvgpos.h<br>
+freetype/src/otvalid/otvgsub.c<br>
+freetype/src/otvalid/otvjstf.c<br>
+freetype/src/otvalid/otvmath.c<br>
+freetype/src/otvalid/otvmod.c<br>
+freetype/src/otvalid/otvmod.h<br>
+freetype/src/otvalid/rules.mk<br>
+freetype/src/pcf/Jamfile<br>
+freetype/src/pcf/README<br>
+freetype/src/pcf/pcf.c<br>
+freetype/src/pcf/pcf.h<br>
+freetype/src/pcf/pcfdrivr.c<br>
+freetype/src/pcf/pcfread.c<br>
+freetype/src/pfr/Jamfile<br>
+freetype/src/pfr/module.mk<br>
+freetype/src/pfr/pfr.c<br>
+freetype/src/pfr/pfrcmap.c<br>
+freetype/src/pfr/pfrcmap.h<br>
+freetype/src/pfr/pfrdrivr.c<br>
+freetype/src/pfr/pfrdrivr.h<br>
+freetype/src/pfr/pfrerror.h<br>
+freetype/src/pfr/pfrgload.c<br>
+freetype/src/pfr/pfrgload.h<br>
+freetype/src/pfr/pfrload.c<br>
+freetype/src/pfr/pfrload.h<br>
+freetype/src/pfr/pfrobjs.c<br>
+freetype/src/pfr/pfrobjs.h<br>
+freetype/src/pfr/pfrsbit.c<br>
+freetype/src/pfr/pfrsbit.h<br>
+freetype/src/pfr/pfrtypes.h<br>
+freetype/src/pfr/rules.mk<br>
+freetype/src/psaux/Jamfile<br>
+freetype/src/psaux/afmparse.c<br>
+freetype/src/psaux/afmparse.h<br>
+freetype/src/psaux/cffdecode.c<br>
+freetype/src/psaux/cffdecode.h<br>
+freetype/src/psaux/module.mk<br>
+freetype/src/psaux/psarrst.c<br>
+freetype/src/psaux/psarrst.h<br>
+freetype/src/psaux/psaux.c<br>
+freetype/src/psaux/psauxerr.h<br>
+freetype/src/psaux/psauxmod.c<br>
+freetype/src/psaux/psauxmod.h<br>
+freetype/src/psaux/psblues.c<br>
+freetype/src/psaux/psblues.h<br>
+freetype/src/psaux/psconv.c<br>
+freetype/src/psaux/psconv.h<br>
+freetype/src/psaux/pserror.c<br>
+freetype/src/psaux/pserror.h<br>
+freetype/src/psaux/psfixed.h<br>
+freetype/src/psaux/psfont.c<br>
+freetype/src/psaux/psfont.h<br>
+freetype/src/psaux/psft.c<br>
+freetype/src/psaux/psft.h<br>
+freetype/src/psaux/psglue.h<br>
+freetype/src/psaux/pshints.c<br>
+freetype/src/psaux/pshints.h<br>
+freetype/src/psaux/psintrp.c<br>
+freetype/src/psaux/psintrp.h<br>
+freetype/src/psaux/psobjs.c<br>
+freetype/src/psaux/psobjs.h<br>
+freetype/src/psaux/psread.c<br>
+freetype/src/psaux/psread.h<br>
+freetype/src/psaux/psstack.c<br>
+freetype/src/psaux/psstack.h<br>
+freetype/src/psaux/pstypes.h<br>
+freetype/src/psaux/rules.mk<br>
+freetype/src/psaux/t1cmap.c<br>
+freetype/src/psaux/t1cmap.h<br>
+freetype/src/psaux/t1decode.c<br>
+freetype/src/psaux/t1decode.h<br>
+freetype/src/pshinter/Jamfile<br>
+freetype/src/pshinter/module.mk<br>
+freetype/src/pshinter/pshalgo.c<br>
+freetype/src/pshinter/pshalgo.h<br>
+freetype/src/pshinter/pshglob.c<br>
+freetype/src/pshinter/pshglob.h<br>
+freetype/src/pshinter/pshinter.c<br>
+freetype/src/pshinter/pshmod.c<br>
+freetype/src/pshinter/pshmod.h<br>
+freetype/src/pshinter/pshnterr.h<br>
+freetype/src/pshinter/pshpic.c<br>
+freetype/src/pshinter/pshpic.h<br>
+freetype/src/pshinter/pshrec.c<br>
+freetype/src/pshinter/pshrec.h<br>
+freetype/src/pshinter/rules.mk<br>
+freetype/src/psnames/Jamfile<br>
+freetype/src/psnames/module.mk<br>
+freetype/src/psnames/psmodule.c<br>
+freetype/src/psnames/psmodule.h<br>
+freetype/src/psnames/psnamerr.h<br>
+freetype/src/psnames/psnames.c<br>
+freetype/src/psnames/pspic.c<br>
+freetype/src/psnames/pspic.h<br>
+freetype/src/psnames/pstables.h<br>
+freetype/src/psnames/rules.mk<br>
+freetype/src/raster/Jamfile<br>
+freetype/src/raster/ftmisc.h<br>
+freetype/src/raster/ftraster.c<br>
+freetype/src/raster/ftraster.h<br>
+freetype/src/raster/ftrend1.c<br>
+freetype/src/raster/ftrend1.h<br>
+freetype/src/raster/module.mk<br>
+freetype/src/raster/raster.c<br>
+freetype/src/raster/rasterrs.h<br>
+freetype/src/raster/rastpic.c<br>
+freetype/src/raster/rastpic.h<br>
+freetype/src/raster/rules.mk<br>
+freetype/src/sfnt/Jamfile<br>
+freetype/src/sfnt/module.mk<br>
+freetype/src/sfnt/pngshim.c<br>
+freetype/src/sfnt/pngshim.h<br>
+freetype/src/sfnt/rules.mk<br>
+freetype/src/sfnt/sfdriver.c<br>
+freetype/src/sfnt/sfdriver.h<br>
+freetype/src/sfnt/sferrors.h<br>
+freetype/src/sfnt/sfnt.c<br>
+freetype/src/sfnt/sfntpic.c<br>
+freetype/src/sfnt/sfntpic.h<br>
+freetype/src/sfnt/sfobjs.c<br>
+freetype/src/sfnt/sfobjs.h<br>
+freetype/src/sfnt/ttbdf.c<br>
+freetype/src/sfnt/ttbdf.h<br>
+freetype/src/sfnt/ttcmap.c<br>
+freetype/src/sfnt/ttcmap.h<br>
+freetype/src/sfnt/ttcmapc.h<br>
+freetype/src/sfnt/ttkern.c<br>
+freetype/src/sfnt/ttkern.h<br>
+freetype/src/sfnt/ttload.c<br>
+freetype/src/sfnt/ttload.h<br>
+freetype/src/sfnt/ttmtx.c<br>
+freetype/src/sfnt/ttmtx.h<br>
+freetype/src/sfnt/ttpost.c<br>
+freetype/src/sfnt/ttpost.h<br>
+freetype/src/sfnt/ttsbit.c<br>
+freetype/src/sfnt/ttsbit.h<br>
+freetype/src/smooth/Jamfile<br>
+freetype/src/smooth/ftgrays.c<br>
+freetype/src/smooth/ftgrays.h<br>
+freetype/src/smooth/ftsmerrs.h<br>
+freetype/src/smooth/ftsmooth.c<br>
+freetype/src/smooth/ftsmooth.h<br>
+freetype/src/smooth/ftspic.c<br>
+freetype/src/smooth/ftspic.h<br>
+freetype/src/smooth/module.mk<br>
+freetype/src/smooth/rules.mk<br>
+freetype/src/smooth/smooth.c<br>
+freetype/src/tools/afblue.pl<br>
+freetype/src/tools/apinames.c<br>
+freetype/src/tools/docmaker/content.py<br>
+freetype/src/tools/docmaker/docbeauty.py<br>
+freetype/src/tools/docmaker/docmaker.py<br>
+freetype/src/tools/docmaker/formatter.py<br>
+freetype/src/tools/docmaker/sources.py<br>
+freetype/src/tools/docmaker/tohtml.py<br>
+freetype/src/tools/docmaker/utils.py<br>
+freetype/src/tools/ftfuzzer/README<br>
+freetype/src/tools/ftfuzzer/ftfuzzer.cc<br>
+freetype/src/tools/ftfuzzer/ftmutator.cc<br>
+freetype/src/tools/ftfuzzer/rasterfuzzer.cc<br>
+freetype/src/tools/ftfuzzer/runinput.cc<br>
+freetype/src/tools/ftrandom/ftrandom.c<br>
+freetype/src/tools/glnames.py<br>
+freetype/src/tools/update-copyright-year<br>
+freetype/src/truetype/Jamfile<br>
+freetype/src/truetype/module.mk<br>
+freetype/src/truetype/rules.mk<br>
+freetype/src/truetype/truetype.c<br>
+freetype/src/truetype/ttdriver.c<br>
+freetype/src/truetype/ttdriver.h<br>
+freetype/src/truetype/tterrors.h<br>
+freetype/src/truetype/ttgload.c<br>
+freetype/src/truetype/ttgload.h<br>
+freetype/src/truetype/ttgxvar.c<br>
+freetype/src/truetype/ttgxvar.h<br>
+freetype/src/truetype/ttinterp.c<br>
+freetype/src/truetype/ttinterp.h<br>
+freetype/src/truetype/ttobjs.c<br>
+freetype/src/truetype/ttobjs.h<br>
+freetype/src/truetype/ttpic.c<br>
+freetype/src/truetype/ttpic.h<br>
+freetype/src/truetype/ttpload.c<br>
+freetype/src/truetype/ttpload.h<br>
+freetype/src/truetype/ttsubpix.c<br>
+freetype/src/truetype/ttsubpix.h<br>
+freetype/src/type1/Jamfile<br>
+freetype/src/type1/module.mk<br>
+freetype/src/type1/rules.mk<br>
+freetype/src/type1/t1afm.c<br>
+freetype/src/type1/t1afm.h<br>
+freetype/src/type1/t1driver.c<br>
+freetype/src/type1/t1driver.h<br>
+freetype/src/type1/t1errors.h<br>
+freetype/src/type1/t1gload.c<br>
+freetype/src/type1/t1gload.h<br>
+freetype/src/type1/t1load.c<br>
+freetype/src/type1/t1load.h<br>
+freetype/src/type1/t1objs.c<br>
+freetype/src/type1/t1objs.h<br>
+freetype/src/type1/t1parse.c<br>
+freetype/src/type1/t1parse.h<br>
+freetype/src/type1/t1tokens.h<br>
+freetype/src/type1/type1.c<br>
+freetype/src/type42/Jamfile<br>
+freetype/src/type42/module.mk<br>
+freetype/src/type42/rules.mk<br>
+freetype/src/type42/t42drivr.c<br>
+freetype/src/type42/t42drivr.h<br>
+freetype/src/type42/t42error.h<br>
+freetype/src/type42/t42objs.c<br>
+freetype/src/type42/t42objs.h<br>
+freetype/src/type42/t42parse.c<br>
+freetype/src/type42/t42parse.h<br>
+freetype/src/type42/t42types.h<br>
+freetype/src/type42/type42.c<br>
+freetype/src/winfonts/Jamfile<br>
+freetype/src/winfonts/fnterrs.h<br>
+freetype/src/winfonts/module.mk<br>
+freetype/src/winfonts/rules.mk<br>
+freetype/src/winfonts/winfnt.c<br>
+freetype/src/winfonts/winfnt.h<br>
+freetype/vms_make.com<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-05-16 22:25:06 -0700
+</strong>
+<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ddace435eb99ea1c8a517f4ec94307cfe0743bce">ddace435eb99ea1c8a517f4ec94307cfe0743bce</a>
+<blockquote>
+<p>
+ Fixup msvclib.mak that had seriously bit-rotted.<br>
+<br>
+ Mainly pulling macro definition in from msvc.mak and add missing FEATURE_DEVS<br>
+ and change the default device to ppmraw (more useful than ljet2).<br>
+<br>
+base/msvclib.mak<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-05-16 22:22:46 -0700
+</strong>
+<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=eab096dcf3d528c4a533ab1fb0616179dd0ee4e6">eab096dcf3d528c4a533ab1fb0616179dd0ee4e6</a>
+<blockquote>
+<p>
+ Add missing dependency for sicclib (md5 is needed for icc cache hash)<br>
+<br>
+base/lib.mak<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-05-16 13:35:26 -0700
+</strong>
+<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cee69d4f50ff9a860040b8afdeb2cdb65a7252d8">cee69d4f50ff9a860040b8afdeb2cdb65a7252d8</a>
+<blockquote>
+<p>
+ Rename &quot;rand&quot; function to &quot;gs_rand&quot; to avoid name clash on Windows<br>
+<br>
+ Apparently (at least with VS 2015) stdlib.h contains a declaration for<br>
+ &quot;rand&quot; that clashes with the local version.<br>
+<br>
+base/gslib.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-05-14 22:33:26 -0700
+</strong>
+<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fc42e417956d4bf3b3b2d7138c550e04f62c3159">fc42e417956d4bf3b3b2d7138c550e04f62c3159</a>
+<blockquote>
+<p>
+ Fix some InterpolateControl issues.<br>
+<br>
+ Some devices (such as clist) rely on image-&gt;Interpolate to determine how<br>
+ to handle the image. Rather than checking dev-&gt;interpolate control there,<br>
+ and look for other devices that may also need it, do the force in the<br>
+ gs_image_begin_typed. Also, fix gs_pdf14_device_copy_params to copy the<br>
+ interpolate_control.<br>
+<br>
+base/gdevp14.c<br>
+base/gsimage.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-05-15 21:36:30 +0100
+</strong>
+<br>Shailesh Mistry &lt;shailesh.mistry@hotmail.co.uk&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f90f090c0a5c3e5744d3ec6f0430fbe1a86ac44c">f90f090c0a5c3e5744d3ec6f0430fbe1a86ac44c</a>
+<blockquote>
+<p>
+ Bug 697545 : Prevent SEGV in freetype if running out of memory.<br>
+<br>
+ Prevent SEGV when trying to use buffer after memory failure. This patch has<br>
+ been accepted by the freetype team as commit e0015f7612cf07ff80561475321ce1f98c7c2b88<br>
+<br>
+ Error created using :-<br>
+ MEMENTO_FAILAT=17104 ./membin/gpcl6 -sDEVICE=pbmraw -dMaxBitmap=2000 -o /dev/null ./tests_private/pcl/pcl5cfts/fts.0051<br>
+<br>
+freetype/src/autofit/afcjk.c<br>
+freetype/src/autofit/aflatin.c<br>
+freetype/src/autofit/afshaper.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-05-09 11:31:38 -0700
+</strong>
+<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=43f429a2508e72d36a3b27671c8d7e43f1bbc591">43f429a2508e72d36a3b27671c8d7e43f1bbc591</a>
+<blockquote>
+<p>
+ Increase the data_size for pattern-clist to 128k (from 32K).<br>
+<br>
+ The tile cache is kept in the clist buffer, and there are a few files that<br>
+ trip over the limit of the number of hash slots with the small data_size,<br>
+ particularly comparefiles/Bug689851.pdf at 72 dpi. With this file, the clist<br>
+ size is reduced by about 65%. Other than the pattern-clist, the tile cache<br>
+ seems to work adequately without needing to delete tiles.<br>
+<br>
+ Also this means that more data can be accumulated for image_data before<br>
+ needing to flush the buffer to the memory_clist storage, which should<br>
+ improve performance a bit (but pattern-clist is never going to be fast).<br>
+<br>
+base/gxpcmap.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-04-26 20:11:31 +0100
+</strong>
+<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9df005ac54c94dc986c3ed94b24d5ecdfe03582b">9df005ac54c94dc986c3ed94b24d5ecdfe03582b</a>
+<blockquote>
+<p>
+ Fix problem with transparency and ROPs.<br>
+<br>
+ A comment from 1998 in gdevrop.c indicates that<br>
+ if we are given a LOP that says &quot;S is transparent&quot;, and<br>
+ S isn't used, then we should ignore that flag. (Similarly<br>
+ for T). Tests seem to indicate that this is indeed true<br>
+ (See page 12 of C425.bin for an example).<br>
+<br>
+ Unfortunately, when we start 'folding' LOPs down onto simpler<br>
+ ones, we can start with a LOP where S (or T) matters, and<br>
+ end up with one where it looks like it doesn't. As such we<br>
+ introduce another flag so we can avoid trying to remove<br>
+ the S/T transparency flags after we have started to fold the<br>
+ rop down.<br>
+<br>
+ We use this in mem_gray8_rgb24_strip_copy_rop, and rop_get_run_op<br>
+ to ensure we don't throw away transparency by mistake.<br>
+<br>
+ For example, in mem_gray8_rgb24_strip_copy_rop when called with<br>
+ lop=0x2fc, with S as a bitmap where both colors are the same, the<br>
+ current code spots that S is always 1, and rewrites the rop to be<br>
+ 0xff. This in turn leads to T not being required, so it is ignored,<br>
+ despite the fact that T should still be consulted for transparency.<br>
+<br>
+ (Check that page 12 of C425.bin is still OK!)<br>
+<br>
+base/gdevmr8n.c<br>
+base/gsroprun.c<br>
+base/gsropt.h<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-05-10 13:58:34 -0600
+</strong>
+<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=30aa9aee30bc0324359df1f931efb75c5a2c5dd7">30aa9aee30bc0324359df1f931efb75c5a2c5dd7</a>
+<blockquote>
+<p>
+ Only add the source to the ROP if it isn't already specified.<br>
+<br>
+ The previous code unconditionally added the source to the ROP, so any<br>
+ ROP which contained ~S was changed to S. With the extra logic, the<br>
+ expression to determine the lop actual paramater was getting<br>
+ unreadable so it has been split up.<br>
+<br>
+base/gxdcolor.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-05-09 17:34:43 +0100
+</strong>
+<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8e31bcbf7214568b09a00683a19f7c4e847618f6">8e31bcbf7214568b09a00683a19f7c4e847618f6</a>
+<blockquote>
+<p>
+ Tweak previous fix to rounding in image code.<br>
+<br>
+ Back in September 2016, commit bffe2011e1 went in, entitled &quot;Fix bug<br>
+ 69707. SMask subpixel offset must match image offset.&quot;<br>
+<br>
+ In this, an adjustment was applied to the dda to attempt to make it<br>
+ match the rounding used in the mono case.<br>
+<br>
+ This adjustment was made *after* the position of the first edge was<br>
+ made, rather than after it, resulting in a slight difference to the<br>
+ size of the first pixel of a run.<br>
+<br>
+ This error was spotted when comparing the output of an experimental<br>
+ optimisation to use memcpy for 1:1 runs of data.<br>
+<br>
+base/gxicolor.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-05-08 12:37:07 +0100
+</strong>
+<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f302fbc59b974a167a7a0023ac6f9e89ed27d243">f302fbc59b974a167a7a0023ac6f9e89ed27d243</a>
+<blockquote>
+<p>
+ Honor the single object clump flag when allocating strings<br>
+<br>
+ When checking whether a given clump was a candidate to allocate a string,<br>
+ the code was not checking the flag that marks the clump as being for a<br>
+ single object. That could lead to the clump being freed (with it's original,<br>
+ single object content, along with the string) when the string(s) were still<br>
+ in use.<br>
+<br>
+ This is better than resetting the flag since single object clumps are such<br>
+ for a reason (they implement immovable memory), and we *never* want<br>
+ immovable memory to become movable<br>
+<br>
+base/gsalloc.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-05-05 20:23:13 +0100
+</strong>
+<br>Shailesh Mistry &lt;shailesh.mistry@hotmail.co.uk&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e1652d0b73989b77a914f6a0de58ec6f53fc8e01">e1652d0b73989b77a914f6a0de58ec6f53fc8e01</a>
+<blockquote>
+<p>
+ Bug 697545 : Prevent SEGV after gs_stroke.<br>
+<br>
+ Prevent SEGV if memory allocation fails.<br>
+<br>
+ Error created using :-<br>
+ MEMENTO_FAILAT=9971 ./membin/gpcl6 -sDEVICE=pbmraw -dMaxBitmap=2000 -o /dev/null ./tests_private/pcl/pcl5cfts/fts.0010<br>
+<br>
+base/gspaint.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-05-05 22:49:20 +0100
+</strong>
+<br>Shailesh Mistry &lt;shailesh.mistry@hotmail.co.uk&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=93d78c6299905fe0a192840015f71820772be95c">93d78c6299905fe0a192840015f71820772be95c</a>
+<blockquote>
+<p>
+ Bug 697545 : Fix memory leak in gx_image_enum_begin.<br>
+<br>
+ Fix memory leak due to buffer not being freed on error.<br>
+<br>
+ Error created using :-<br>
+ MEMENTO_FAILAT=10035 ./membin/gpcl6 -sDEVICE=pbmraw -dMaxBitmap=2000 -o /dev/null ./tests_private/pcl/pcl5cfts/fts.0010<br>
+<br>
+base/gxipixel.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-05-05 21:28:41 +0100
+</strong>
+<br>Shailesh Mistry &lt;shailesh.mistry@hotmail.co.uk&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2b2fef0e97c148795af8c4c08b261f2807f1ba52">2b2fef0e97c148795af8c4c08b261f2807f1ba52</a>
+<blockquote>
+<p>
+ Bug 697545 : Prevent SEGV after fill_with_rule.<br>
+<br>
+ Prevent SEGV if memory allocation fails.<br>
+<br>
+ Error created using :-<br>
+ MEMENTO_FAILAT=9999 ./membin/gpcl6 -sDEVICE=pbmraw -dMaxBitmap=2000 -o /dev/null ./tests_private/pcl/pcl5cfts/fts.0010<br>
+<br>
+base/gspaint.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-05-04 19:31:59 +0100
+</strong>
+<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9e8ef6c2f2086adbf784ddbe71fe2799afc4002b">9e8ef6c2f2086adbf784ddbe71fe2799afc4002b</a>
+<blockquote>
+<p>
+ Fix image skip logic (again).<br>
+<br>
+ The device to be used is not penum-&gt;dev, that'd be far too sensible!<br>
+<br>
+ Pass in the actual device to be used.<br>
+<br>
+base/gxidata.c<br>
+base/gximage.h<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-05-03 22:31:31 +0100
+</strong>
+<br>Shailesh Mistry &lt;shailesh.mistry@hotmail.co.uk&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7fa6e4a640857f6cfb1d520e65376c0304594980">7fa6e4a640857f6cfb1d520e65376c0304594980</a>
+<blockquote>
+<p>
+ Bug 697545 : Fix memory leak in gx_gstate_dev_ht_install.<br>
+<br>
+ Fix memory leak due to cache not being freed on error.<br>
+<br>
+ Error created using :-<br>
+ MEMENTO_FAILAT=10111 ./membin/gpcl6 -sDEVICE=pbmraw -dMaxBitmap=2000 -o /dev/null ./pcl/examples/owl.pcl<br>
+<br>
+base/gsht.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-05-03 12:00:11 -0700
+</strong>
+<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9df84425aab2009f6335d57b5c19da2ac49294c4">9df84425aab2009f6335d57b5c19da2ac49294c4</a>
+<blockquote>
+<p>
+ Clean up some left over RECT_RECOVER code, delete band_code from state<br>
+<br>
+base/gxcldev.h<br>
+base/gxclimag.c<br>
+base/gxclrect.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-05-02 08:34:52 -0700
+</strong>
+<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fe6b6679bced0f6f9b617e72278c538da8386b5c">fe6b6679bced0f6f9b617e72278c538da8386b5c</a>
+<blockquote>
+<p>
+ Remove unused clist command definitions, document unused code values.<br>
+<br>
+ In preparation for upcoming clist changes for tiles, do some clean up of<br>
+ the definitions and document unused command codes. Note that there are<br>
+ still commands with flag bits where there are unused bits when certain<br>
+ flags are set, e.g. copy_mono_planes, low 3 bits unused if copy_use_tile<br>
+ is set, but using these code combinations would need changes in the<br>
+ clist_playback_band reader.<br>
+<br>
+base/gxcldev.h<br>
+base/gxclimag.c<br>
+base/gxclpath.h<br>
+base/gxclrast.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-05-03 18:49:03 +0100
+</strong>
+<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a080da17f4d060b4e23d85b35989df92bb4bf76c">a080da17f4d060b4e23d85b35989df92bb4bf76c</a>
+<blockquote>
+<p>
+ Remove outdated comment.<br>
+<br>
+base/gxicolor.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-05-03 11:51:22 +0100
+</strong>
+<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=23de52cfaf6e263dde824bd7be0b8d9d1d2cd053">23de52cfaf6e263dde824bd7be0b8d9d1d2cd053</a>
+<blockquote>
+<p>
+ Fix quirk in image enumerator creation routines.<br>
+<br>
+ When we start an image, the image code runs through the handlers<br>
+ for different types of image until it finds one that can handle<br>
+ the required type.<br>
+<br>
+ These handlers are queried with the current device in as penum-&gt;dev.<br>
+<br>
+ The image code then sets up any clip or rop device on top of this<br>
+ device.<br>
+<br>
+ If the handlers were to call device functions, they would be in<br>
+ the somewhat odd position of calling a different device in the setup<br>
+ phase than they would be calling in the processing phase. This<br>
+ upsets a forthcoming commit.<br>
+<br>
+ The fix is to ensure that any clip and rop devices are setup BEFORE<br>
+ the image handlers are called.<br>
+<br>
+base/gxipixel.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-04-29 10:28:48 +0100
+</strong>
+<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7b4ad6025f0576e2adb971230a9a2dfb62335a13">7b4ad6025f0576e2adb971230a9a2dfb62335a13</a>
+<blockquote>
+<p>
+ Update doc/thirdparty.htm<br>
+<br>
+doc/thirdparty.htm<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-04-25 14:22:03 +0100
+</strong>
+<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f7bfa8db8f1407f70253667d832f3b219b434559">f7bfa8db8f1407f70253667d832f3b219b434559</a>
+<blockquote>
+<p>
+ Fix source + texture both data in mem_gray8_rgb24_strip_copy_rop.<br>
+<br>
+ Using rop rather than lop means transparency was broken in the<br>
+ (unusual) source + texture both being data based case.<br>
+<br>
+ Also, we were failing to update the source pointer, causing odd<br>
+ repeats in output.<br>
+<br>
+base/gdevmr8n.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-04-27 07:52:52 -0600
+</strong>
+<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2fd21f767d9b4065fd4f3ef1319ad6dbee8a2ffd">2fd21f767d9b4065fd4f3ef1319ad6dbee8a2ffd</a>
+<blockquote>
+<p>
+ Change ownership of jbig2 to Sebastian.<br>
+<br>
+doc/who_owns_what.txt<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-04-27 11:27:44 +0100
+</strong>
+<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5ff675bcb1ce0a1349a81c4c2dbfde20769616fa">5ff675bcb1ce0a1349a81c4c2dbfde20769616fa</a>
+<blockquote>
+<p>
+ pdf_info.ps - report if a PDF file uses XFA forms<br>
+<br>
+toolbin/pdf_info.ps<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-04-26 19:01:44 +0100
+</strong>
+<br>Shailesh Mistry &lt;shailesh.mistry@hotmail.co.uk&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=133d0c54ba05f887f67c441ceda59f49cf563902">133d0c54ba05f887f67c441ceda59f49cf563902</a>
+<blockquote>
+<p>
+ Bug 697545 : Fix memory leak in clist_open.<br>
+<br>
+ Fix memory leak due to cache not being freed on error.<br>
+<br>
+ Error created using :-<br>
+ MEMENTO_FAILAT=1835 ./membin/gpcl6 -sDEVICE=pbmraw -sDEVICE=pbmraw -o /dev/null ./pcl/examples/owl.pcl<br>
+<br>
+base/gxclist.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-04-25 09:55:51 -0700
+</strong>
+<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4609498d02a91f954636124d5f5699794ffac48a">4609498d02a91f954636124d5f5699794ffac48a</a>
+<blockquote>
+<p>
+ Fix bug 697671: Banding/Page mode mismatch<br>
+<br>
+ The simplified case had a character (copy_mono) followed by a rect<br>
+ fill.<br>
+<br>
+ The copy_mono for the character sets the rect.height clamped to the<br>
+ &quot;cropping_max&quot; (dev-&gt;height) for the band in the writer, but it doesn't<br>
+ actually write the height to the clist for that band. Then the reader<br>
+ was using the entire bitmap height, but that went past the end of the<br>
+ device, so the next time the state.rect.height was used in the reader,<br>
+ it was wrong.<br>
+<br>
+base/gxclrast.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-04-25 20:26:43 +0100
+</strong>
+<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=bf9c9faf78caacc7e90faf04b50611153a64d014">bf9c9faf78caacc7e90faf04b50611153a64d014</a>
+<blockquote>
+<p>
+ Update clusterpush.pl to allow for larger files.<br>
+<br>
+toolbin/localcluster/clusterpush.pl<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-04-24 16:00:31 +0100
+</strong>
+<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8197eaf98c552991a0b7f8068ff3fcce56c07803">8197eaf98c552991a0b7f8068ff3fcce56c07803</a>
+<blockquote>
+<p>
+ Bug 699201: Fix alignment of rendering bands memory<br>
+<br>
+ The bottom section of the &quot;raster buffer&quot;, when rendering through the page<br>
+ clist, is reserved as a cache (tile cache, to be specific). Hence to bottom<br>
+ address of the memory we actually render into starts immediately after the<br>
+ cache.<br>
+<br>
+ No account was taken when setting up that cache size of the alignment expected<br>
+ by the rendering code.<br>
+<br>
+ We'll now ensure that the the cache ends, and the raster band memory starts<br>
+ on an appropriately aligned address.<br>
+<br>
+base/gxclist.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-04-24 15:22:15 +0100
+</strong>
+<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=610862e06b739430a2994dc4a0c399fa21900521">610862e06b739430a2994dc4a0c399fa21900521</a>
+<blockquote>
+<p>
+ Tweak MSVC Profile build settings.<br>
+<br>
+ While attempting to debug an unrelated issue, I found a note on<br>
+ an MSVC forum from an MS developer suggesting that we should use<br>
+ /Profile rather than /PROFILE or /profile as the flags. They<br>
+ *should* do the same thing, but the suggestion is that there<br>
+ might be a bug in the MS linker.<br>
+<br>
+ Committing this here as it certainly doesn't hurt, and might save<br>
+ someone hours in future.<br>
+<br>
+psi/msvc.mak<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-04-24 11:57:28 +0100
+</strong>
+<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0be413a3f3a24c3d55062273cd37e8fcac7c0c4f">0be413a3f3a24c3d55062273cd37e8fcac7c0c4f</a>
+<blockquote>
+<p>
+ Fix mem_gray8_rgb24_strip_copy_rop.<br>
+<br>
+ A couple of cases in this routine were failing to increment<br>
+ the destination pointer after writing. I guess this shows<br>
+ that a couple of cases are rarely used for partial scanlines.<br>
+<br>
+base/gdevmr8n.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-04-20 23:50:59 +0100
+</strong>
+<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c56b2c2d72ef86f3e45882dd5b35a772ce79e8f9">c56b2c2d72ef86f3e45882dd5b35a772ce79e8f9</a>
+<blockquote>
+<p>
+ Avoid 'const' warning.<br>
+<br>
+base/gxi12bit.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-04-20 14:45:52 +0100
+</strong>
+<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7657398e7574f4a54eb35ea757a7c3037fe7c0e5">7657398e7574f4a54eb35ea757a7c3037fe7c0e5</a>
+<blockquote>
+<p>
+ Further simplification to image_render_icc_... functions.<br>
+<br>
+ Avoid needless alternations in the middle of the loop in<br>
+ exchange for a single function call.<br>
+<br>
+base/gxcmap.c<br>
+base/gxcmap.h<br>
+base/gxi12bit.c<br>
+base/gxicolor.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-04-20 18:10:12 +0100
+</strong>
+<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4a2f6848f38c60eb39a5467c951cfdc06c334a19">4a2f6848f38c60eb39a5467c951cfdc06c334a19</a>
+<blockquote>
+<p>
+ Apply same simplification/optimisations to image_render_icc16<br>
+<br>
+ Apply the same changes to image_render_icc16 as we did just a few<br>
+ commits ago.<br>
+<br>
+base/gxi12bit.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-04-19 19:13:50 +0100
+</strong>
+<br>Shailesh Mistry &lt;shailesh.mistry@hotmail.co.uk&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7b539b765dcc960d257bffbcfef8a496120887a8">7b539b765dcc960d257bffbcfef8a496120887a8</a>
+<blockquote>
+<p>
+ Bug 697545 : Prevent SEGV in c_param_add.<br>
+<br>
+ Prevent SEGV if pkey memory allocation fails.<br>
+<br>
+ Error created using :-<br>
+ MEMENTO_FAILAT=1823 ./membin/gpcl6 -sDEVICE=pbmraw -r300 -dMaxBitmap=2000 -o /dev/null ./pcl/examples/owl.pcl<br>
+<br>
+base/gscparam.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-04-16 20:34:46 +0100
+</strong>
+<br>Shailesh Mistry &lt;shailesh.mistry@hotmail.co.uk&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=28c25a7aa12ab36996e12850dfc8e0935c0e4437">28c25a7aa12ab36996e12850dfc8e0935c0e4437</a>
+<blockquote>
+<p>
+ Bug 697545 : Prevent SEGV in pcfont_do_reset.<br>
+<br>
+ Prevent SEGV if memory allocation fails.<br>
+<br>
+ Error created using :-<br>
+ MEMENTO_FAILAT=1908 ./membin/gpcl6 -sDEVICE=pbmraw -r300 -o /dev/null ./pcl/examples/owl.pcl<br>
+<br>
+pcl/pcl/pcfont.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-04-19 17:42:06 +0100
+</strong>
+<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b35f89d9bef02a02c55a377c6797afcbbe78664d">b35f89d9bef02a02c55a377c6797afcbbe78664d</a>
+<blockquote>
+<p>
+ Simplify some image_render code routines.<br>
+<br>
+ Primarily these cut down on needlessly duplicated code.<br>
+<br>
+ The skew case should actually benefit in speed, because we don't<br>
+ pointlessly redo the color mapping for every pixel.<br>
+<br>
+base/gxicolor.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-04-17 21:38:31 +0100
+</strong>
+<br>Shailesh Mistry &lt;shailesh.mistry@hotmail.co.uk&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2c25f3c8582749cc9641d12ca4eb51adefa6d04d">2c25f3c8582749cc9641d12ca4eb51adefa6d04d</a>
+<blockquote>
+<p>
+ Bug 697545 : Fix memory leak in rc_unshare_struct.<br>
+<br>
+ Rearrange order of macro so that the memory is freed even if the call to<br>
+ rc_alloc_struct_1 fails.<br>
+<br>
+ Error created using :-<br>
+ MEMENTO_FAILAT=10044 ./membin/gpcl6 -sDEVICE=pbmraw -r300 -o /dev/null ./pcl/examples/owl.pcl<br>
+<br>
+base/gsrefct.h<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-04-19 13:41:33 +0100
+</strong>
+<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8f37f0e4f6325ea8f58194d81a8a6e3321e6660e">8f37f0e4f6325ea8f58194d81a8a6e3321e6660e</a>
+<blockquote>
+<p>
+ Remove some experimental code that was ifdef'ed out<br>
+<br>
+base/gxfapi.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-04-19 13:38:30 +0100
+</strong>
+<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e8e91f7046645ac7334516735d06ae5109127892">e8e91f7046645ac7334516735d06ae5109127892</a>
+<blockquote>
+<p>
+ Ensure uncached glyphs have the &quot;text&quot; tag set.<br>
+<br>
+ Glyphs bitmaps being drawn from FAPI, bypassing the glyph cache, were not<br>
+ causing the device's tag to be set to text.<br>
+<br>
+base/gxfapi.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-04-18 13:54:13 +0100
+</strong>
+<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8f912519ee1d7407126479fefc2210bc69f9e11a">8f912519ee1d7407126479fefc2210bc69f9e11a</a>
+<blockquote>
+<p>
+ Fix compiler warning with debug build<br>
+<br>
+ In a debug build, to facilitate logging/debugging, the rc_ajust() macro<br>
+ calls a function to trace the reference count changes. The client name (cname)<br>
+ parameter should be declared const to avoid a compiler warning.<br>
+<br>
+base/gsmemory.c<br>
+base/gsrefct.h<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-04-18 10:11:50 +0100
+</strong>
+<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b8c65eab50076cfd56f0301ec764b30df9d86ae3">b8c65eab50076cfd56f0301ec764b30df9d86ae3</a>
+<blockquote>
+<p>
+ Bug 699214: Add and use a &quot;no cache&quot; flag for glyphs<br>
+<br>
+ Previously, to avoid using a cached glyph, the PXL code went around the<br>
+ graphics library API to set a flag in the show enumerator that really should<br>
+ only be touched internally.<br>
+<br>
+ This adds the capability to the enumerator for the client to request that no<br>
+ cached glyphs be used for the current block of text, and changes the PXL code<br>
+ to used it.<br>
+<br>
+base/gstext.h<br>
+base/gxchar.c<br>
+pcl/pxl/pxfont.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-04-18 09:07:27 +0100
+</strong>
+<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fd22032d14134f32a42897c9db6a796340a912de">fd22032d14134f32a42897c9db6a796340a912de</a>
+<blockquote>
+<p>
+ Bug 699214 (related): make text and show enums the same<br>
+<br>
+ This is the first part of removing the text enumerator altogether.<br>
+<br>
+base/gxchar.h<br>
+base/gxtext.h<br>
+base/lib.mak<br>
+devices/vector/gdevpdtt.h<br>
+devices/vector/gdevtxtw.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-04-18 15:47:20 +0100
+</strong>
+<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=49dcf2a599434f2cb9e0847a75ad61270d30e68a">49dcf2a599434f2cb9e0847a75ad61270d30e68a</a>
+<blockquote>
+<p>
+ Documentation - document two missing parameters<br>
+<br>
+ These got missed from the documentation when they were implemented.<br>
+<br>
+doc/VectorDevices.htm<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-04-18 15:46:32 +0100
+</strong>
+<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=39b1e54b2968620723bf32e96764c88797714879">39b1e54b2968620723bf32e96764c88797714879</a>
+<blockquote>
+<p>
+ pdfwrite - Guard against trying to output an infinite number<br>
+<br>
+ Bug #699255 &quot; Buffer overflow on pprintg1 due to mishandle postscript file data to pdf&quot;<br>
+<br>
+ The file uses an enormous parameter to xyxhow, causing an overflow in<br>
+ the calculation of text positioning (value &gt; 1e39).<br>
+<br>
+ Since this is basically a nonsense value, and PostScript only supports<br>
+ real values up to 1e38, this patch follows the same approach as for<br>
+ a degenerate CTM, and treats it as 0.<br>
+<br>
+ Adobe Acrobat Distiller throws a limitcheck error, so we could do that<br>
+ instead if this approach proves to be a problem.<br>
+<br>
+devices/vector/gdevpdts.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-04-17 16:09:40 +0100
+</strong>
+<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fb4c58a0e097e39547dde3d46893ce1b05d19539">fb4c58a0e097e39547dde3d46893ce1b05d19539</a>
+<blockquote>
+<p>
+ Remove redundant references to Xfonts.htm<br>
+<br>
+base/unixinst.mak<br>
+doc/Drivers.htm<br>
+doc/Readme.htm<br>
+doc/Use.htm<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-03-30 14:38:28 +0100
+</strong>
+<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=59c722d075cb70fc076c2d41b30f16e0e54a4704">59c722d075cb70fc076c2d41b30f16e0e54a4704</a>
+<blockquote>
+<p>
+ Bug 699160: rejig the .so &quot;loaders&quot; builds.<br>
+<br>
+ The two simple .so &quot;loaders&quot; (gsx and gsc) were built as a single step, source<br>
+ to exe, process. Because of that LDFLAGS wasn't used.<br>
+<br>
+ We'll now separate the compile and link stages, meaning we can properly use<br>
+ CFLAGS and LDFLAGS. It also means we can have more control of the order in<br>
+ which the -L lib search paths are applied.<br>
+<br>
+ Properly pass on debug options, and extend these changes to the PCL/XPS/PDL<br>
+ .so/exe targets.<br>
+<br>
+Makefile.in<br>
+base/unix-dll.mak<br>
+base/unixlink.mak<br>
+configure.ac<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-04-15 12:49:40 -0700
+</strong>
+<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=769ffb76e7cfd5eeff32251d122399f4b729477b">769ffb76e7cfd5eeff32251d122399f4b729477b</a>
+<blockquote>
+<p>
+ Fix warning on exit with ref_count &gt; 0 due to pclxl image handling.<br>
+<br>
+ The pclxl_begin_image gets a link profile, but did not release the<br>
+ link in pclxl_image_end_image causing the ref_count to be wrong.<br>
+<br>
+devices/vector/gdevpx.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-04-15 12:48:20 -0700
+</strong>
+<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e88d8e90de569adedb614a2a7e3dda38063f4d02">e88d8e90de569adedb614a2a7e3dda38063f4d02</a>
+<blockquote>
+<p>
+ Add ref_count debug to icc link cache.<br>
+<br>
+base/gsicc_cache.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-04-11 19:37:07 +0100
+</strong>
+<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=dfbf92a35d2be0aaa35bdb301c0647deec55b054">dfbf92a35d2be0aaa35bdb301c0647deec55b054</a>
+<blockquote>
+<p>
+ Attempt to fix vertical shifts seen in halftoning.<br>
+<br>
+ Differences are evident between old (slow, non SSE based) and new<br>
+ (fast, C/SSE based) halftoning. This is not because of the SSE,<br>
+ but rather because of different calculations in the C that prepares<br>
+ the screen for the fast SSE based thresholding, specifically, I<br>
+ believe, to the calculation of the y offset into the texture tile.<br>
+<br>
+ This commit changes the texture tile y offset calculation in the<br>
+ 'fast' code to involve screen_phase.y, in the hopes that this<br>
+ will better match the 'old' version.<br>
+<br>
+ With this fix in, we see just a few PS/PDF diffs, but lots of PCL<br>
+ diffs (as I guess you'd expect, as PCL makes much more use of this<br>
+ kind of stuff). I've checked a random selection of them, and in all<br>
+ cases the new page mode renderings with the &quot;fast&quot; code match the<br>
+ page mode renderings given by the &quot;old&quot; code.<br>
+<br>
+ There are instances where the clist rendering no longer matches the<br>
+ page mode rendering, but in the tests I've done the clist old code<br>
+ does match the clist fast code. So we are consistent at least. I<br>
+ suspect that there is something up with the way the y_phase is<br>
+ transmitted across the clist, and have opened bug 699209 to<br>
+ track that.<br>
+<br>
+base/gxht_thresh.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-04-11 20:28:23 +0100
+</strong>
+<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b9e0722267e8770c01914da28f924cffcae1c0b8">b9e0722267e8770c01914da28f924cffcae1c0b8</a>
+<blockquote>
+<p>
+ Fix stray debugging code that was breaking windows builds.<br>
+<br>
+base/write_t1.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-04-10 16:01:44 +0100
+</strong>
+<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1da9cf6dd87287b952826e8606a26f97b474c556">1da9cf6dd87287b952826e8606a26f97b474c556</a>
+<blockquote>
+<p>
+ Multiple master font cached glyphs<br>
+<br>
+ In the event that the WeightVector is changed (via setweightvector) on an<br>
+ already defined font object, we had no way to invalidate the glyph cache<br>
+ entries already created for that font, with the previous WeightVector.<br>
+<br>
+ Given that MM fonts generally substitute for an entire use of a &quot;real&quot; font,<br>
+ and changing &quot;mid stream&quot; is rare (and almost entirely restricted to test<br>
+ files), this uses the sledgehammer approach of purging the existing glyphs<br>
+ from the cache.<br>
+<br>
+ In real world use, this is going to have less effect on performance than adding<br>
+ a conditional check on a variable length array of floating point numbers is<br>
+ likely to have.<br>
+<br>
+psi/int.mak<br>
+psi/zchar1.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-01-30 09:31:04 +0000
+</strong>
+<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=36e7d38af2a11b5e4d7117ddd0ebf7326fad7c72">36e7d38af2a11b5e4d7117ddd0ebf7326fad7c72</a>
+<blockquote>
+<p>
+ Bug 698767: Improve handling of multiple master fonts<br>
+<br>
+ The FAPI API didn't really handle the possibility that multiple master fonts<br>
+ could change (via setweightvector) without a call to definefont/setfont etc.<br>
+<br>
+ We now allow two ways for FAPI to handle this: if the scaler in force allows it,<br>
+ we'll set the new weight vector, and carry on as before.<br>
+<br>
+ If the scaler does *not* allow us to change the weight vector &quot;on the fly&quot;,<br>
+ we'll destroy the scaler's font object and related data, and recreate it with<br>
+ the new weight vector in the font dictionary.<br>
+<br>
+base/fapi_ft.c<br>
+base/fapibstm.c<br>
+base/fapiufst.c<br>
+base/gsalloc.c<br>
+base/gxfapi.c<br>
+base/gxfapi.h<br>
+base/write_t1.c<br>
+psi/zfapi.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-04-08 20:34:43 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=890e637bf7a1d8a5e3438c2aab4e0eef33d795f1">890e637bf7a1d8a5e3438c2aab4e0eef33d795f1</a>
+<blockquote>
+<p>
+ jbig2dec: Detect data shortage.<br>
+<br>
+jbig2dec/jbig2_page.c<br>
+jbig2dec/jbig2_segment.c<br>
+jbig2dec/jbig2_text.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-04-08 20:33:33 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=44ff6900ac97d53101c8585880acb9a73631cefe">44ff6900ac97d53101c8585880acb9a73631cefe</a>
+<blockquote>
+<p>
+ jbig2dec: Remember to free halftone GB_stats in case of error.<br>
+<br>
+jbig2dec/jbig2_halftone.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-04-08 20:32:59 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9efdbd90790f87ab9f56a4cd39b703a23c9d3172">9efdbd90790f87ab9f56a4cd39b703a23c9d3172</a>
+<blockquote>
+<p>
+ jbig2dec: Make error messages distinguishable.<br>
+<br>
+jbig2dec/jbig2_symbol_dict.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-04-08 14:58:23 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1fca43f52caa90926169fe1fe845837749bab233">1fca43f52caa90926169fe1fe845837749bab233</a>
+<blockquote>
+<p>
+ jbig2dec: Plug leak of image upon error decoding text region.<br>
+<br>
+jbig2dec/jbig2_symbol_dict.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-04-06 00:41:01 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2b2dcf4ccf401ed210f03c858b304994749fd2b3">2b2dcf4ccf401ed210f03c858b304994749fd2b3</a>
+<blockquote>
+<p>
+ jbig2dec: Improve error handling.<br>
+<br>
+ Some functions detected errors but would not return these<br>
+ to the caller. These functions may now indicate errors:<br>
+<br>
+ jbig2_arith_decode(), jbig2_image_resize()<br>
+<br>
+ Errors detected by following functions were not always<br>
+ handled, but they are now handled properly:<br>
+<br>
+ jbig2_arith_decode(), jbig2_arith_iaid_decode()<br>
+ jbig2_arith_int_ctx_new(), jbig2_build_huffman_table()<br>
+ jbig2_complete_page(), jbig2_image_compose()<br>
+ jbig2_decode_refinement_region(), jbig2_ctx_new()<br>
+ jbig2_image_resize(), jbig2_image_write_pbm()<br>
+ jbig2_image_write_pbm_file(), jbig2_image_write_png()<br>
+ jbig2_image_write_png_file(), jbig2_metadata_add()<br>
+ jbig2_page_add_result(), jbig2_renew()<br>
+ jbig2_strndup()<br>
+<br>
+ Some functions detected errors but did not fail early enough:<br>
+<br>
+ jbig2_decode_pattern_dict(), jbig2_decode_halftone_region()<br>
+<br>
+ jbig2_decode_mmr_line() detected errors but did not produce<br>
+ suitable error messages. This has been rectified.<br>
+<br>
+ Finally, if a subfunction indicates an error by returning an<br>
+ error code, the calling function will report a warning and<br>
+ return, indicating failure.<br>
+<br>
+jbig2dec/jbig2.c<br>
+jbig2dec/jbig2_arith.c<br>
+jbig2dec/jbig2_arith.h<br>
+jbig2dec/jbig2_arith_iaid.c<br>
+jbig2dec/jbig2_arith_iaid.h<br>
+jbig2dec/jbig2_arith_int.c<br>
+jbig2dec/jbig2_arith_int.h<br>
+jbig2dec/jbig2_generic.c<br>
+jbig2dec/jbig2_halftone.c<br>
+jbig2dec/jbig2_image.c<br>
+jbig2dec/jbig2_image_pbm.c<br>
+jbig2dec/jbig2_image_png.c<br>
+jbig2dec/jbig2_metadata.c<br>
+jbig2dec/jbig2_mmr.c<br>
+jbig2dec/jbig2_page.c<br>
+jbig2dec/jbig2_refinement.c<br>
+jbig2dec/jbig2_segment.c<br>
+jbig2dec/jbig2_symbol_dict.c<br>
+jbig2dec/jbig2_text.c<br>
+jbig2dec/jbig2dec.c<br>
+jbig2dec/pbm2png.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-04-06 00:44:10 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7ede8fc2b5e8498619d1e32b6b7fbbf9f926a055">7ede8fc2b5e8498619d1e32b6b7fbbf9f926a055</a>
+<blockquote>
+<p>
+ jbig2dec: Remove unused return value for setting pixel.<br>
+<br>
+jbig2dec/jbig2_image.c<br>
+jbig2dec/jbig2_image.h<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-04-09 21:30:07 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2afeb8384e4db612df56d5f02162767647893a7d">2afeb8384e4db612df56d5f02162767647893a7d</a>
+<blockquote>
+<p>
+ jbig2dec: Remove end of line characters to jbig2_error() messages.<br>
+<br>
+jbig2dec/jbig2_image.c<br>
+jbig2dec/jbig2_symbol_dict.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-04-07 00:12:15 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d38507b3d62d9d0710b1c5122af5db9730167082">d38507b3d62d9d0710b1c5122af5db9730167082</a>
+<blockquote>
+<p>
+ jbig2dec: Fix some cosmetic typos in code/headers/tests.<br>
+<br>
+jbig2dec/jbig2.h<br>
+jbig2dec/jbig2_halftone.c<br>
+jbig2dec/jbig2_huffman.c<br>
+jbig2dec/jbig2_image_png.c<br>
+jbig2dec/jbig2_metadata.c<br>
+jbig2dec/jbig2_page.c<br>
+jbig2dec/jbig2_priv.h<br>
+jbig2dec/jbig2_segment.c<br>
+jbig2dec/jbig2_text.c<br>
+jbig2dec/jbig2dec.c<br>
+jbig2dec/memento.c<br>
+jbig2dec/test_jbig2dec.py<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-03-26 21:57:33 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c0f89bd215d700339429da4375a4eaf89445f872">c0f89bd215d700339429da4375a4eaf89445f872</a>
+<blockquote>
+<p>
+ jbig2dec: Remove unnecessary whitespace.<br>
+<br>
+jbig2dec/jbig2.c<br>
+jbig2dec/jbig2_arith.c<br>
+jbig2dec/jbig2_generic.c<br>
+jbig2dec/jbig2_huffman.c<br>
+jbig2dec/jbig2_symbol_dict.c<br>
+jbig2dec/jbig2_text.c<br>
+jbig2dec/test_jbig2dec.py<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-04-09 11:49:52 +0200
+</strong>
+<br>Tor Andersson &lt;tor.andersson@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=47f3be9b6676ed09e844362b267daae2a1b04a4d">47f3be9b6676ed09e844362b267daae2a1b04a4d</a>
+<blockquote>
+<p>
+ jbig2dec: Make sure to include stdint.h in the generated config_types.h<br>
+<br>
+ The previous commit accidentally broke the autoconf build.<br>
+<br>
+jbig2dec/autogen.sh<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-04-06 12:44:38 +0100
+</strong>
+<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=bda3b5087d136c7839ded79594ac70e9712228e5">bda3b5087d136c7839ded79594ac70e9712228e5</a>
+<blockquote>
+<p>
+ Fix Memento locking problem.<br>
+<br>
+ When calling Memento_event, it would lock, and then call<br>
+ Memento_checkAllMemory which would lock again. This is fine<br>
+ on windows, as locks are recursive, but not on Linux.<br>
+<br>
+base/memento.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-04-04 22:36:24 +0100
+</strong>
+<br>Shailesh Mistry &lt;shailesh.mistry@hotmail.co.uk&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cbbe08d116ae91e0cc0ffa91eb71ec364b4d44a3">cbbe08d116ae91e0cc0ffa91eb71ec364b4d44a3</a>
+<blockquote>
+<p>
+ Bug 697545 : Fix memory leak in gx_pattern_load.<br>
+<br>
+ Fix memory leak due to pattern cache data being allocated but not used.<br>
+<br>
+ Error created using :-<br>
+ MEMENTO_FAILAT=10103 ./membin/gpcl6 -sDEVICE=ppmraw -o /dev/null ./pcl/examples/owl.pcl<br>
+<br>
+base/gxpcmap.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-04-04 18:40:01 +0100
+</strong>
+<br>Shailesh Mistry &lt;shailesh.mistry@hotmail.co.uk&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cbc44b82c2c63ef48c994fb2eced4350e41159aa">cbc44b82c2c63ef48c994fb2eced4350e41159aa</a>
+<blockquote>
+<p>
+ Bug 697545 : Fix memory leak in show_proceed.<br>
+<br>
+ Fix memory leak due to gsave/grestore mismatch.<br>
+<br>
+ Error created using :-<br>
+ MEMENTO_FAILAT=10946 ./membin/gpcl6 -sDEVICE=ppmraw -o /dev/null ./pcl/examples/owl.pcl<br>
+<br>
+base/gxchar.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-04-05 16:28:01 +0100
+</strong>
+<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4372854939842240c7edb58dd0fa285a0c2f15b1">4372854939842240c7edb58dd0fa285a0c2f15b1</a>
+<blockquote>
+<p>
+ Another attempt at fixing the 'skip' logic for halftoned images.<br>
+<br>
+ When rendering images, if the dda is not shared between the<br>
+ halftoner and gs, gs cannot just skip lines that it knows should<br>
+ be clipped, lest the halftoner get confused about it.<br>
+<br>
+ The previous attempt to solve this used a separate 'skip_render'<br>
+ routine, but the decision as to whether to call this or not was<br>
+ itself dependent on the values of the dda. When scaling down<br>
+ scanlines can be completely skipped. In the cases where the dda<br>
+ in gs doesn't match the one in the halftoner exactly we could<br>
+ get dropouts.<br>
+<br>
+ So, a new attempt. Here we introduce a new function call that<br>
+ checks with the halftoner whether the next scanline will be<br>
+ required or not. If it is, gs unpacks the data and passes it in.<br>
+ If not, the data can just be skipped.<br>
+<br>
+base/gxidata.c<br>
+base/gximage.h<br>
+base/gxipixel.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-04-04 18:38:02 +0100
+</strong>
+<br>Shailesh Mistry &lt;shailesh.mistry@hotmail.co.uk&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5886c28f2a7376ad3818dadeb9cc3c6989f7702a">5886c28f2a7376ad3818dadeb9cc3c6989f7702a</a>
+<blockquote>
+<p>
+ Bug 697545 : Fix memory leak in pcl_start_raster.<br>
+<br>
+ Fix memory leak after memory allocation failure.<br>
+<br>
+ Error created using :-<br>
+ MEMENTO_FAILAT=11602 ./membin/gpcl6 -sDEVICE=ppmraw -o /dev/null ./pcl/examples/owl.pcl<br>
+<br>
+pcl/pcl/rtraster.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-04-05 14:12:25 +0100
+</strong>
+<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9ef02a883952ecc225792896a1eabac93e19f143">9ef02a883952ecc225792896a1eabac93e19f143</a>
+<blockquote>
+<p>
+ Bug 699158: Tidy up a validation check<br>
+<br>
+ Use a cleaner check to ensure UFST only gets passed Microtype fonts (from .fco<br>
+ font collections).<br>
+<br>
+ Not sure what I was thinking when I wrote the original check, but it was clearly<br>
+ a bad code day!<br>
+<br>
+base/fapiufst.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-04-05 14:10:54 +0100
+</strong>
+<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=410d5f9372db241713f0e9730ec18edfa117f687">410d5f9372db241713f0e9730ec18edfa117f687</a>
+<blockquote>
+<p>
+ Fix some link typos in Develop.html<br>
+<br>
+doc/Develop.htm<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-04-04 17:30:17 +0100
+</strong>
+<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=bc9e133f81e02e90e9fc9a82853d0aea18cdb905">bc9e133f81e02e90e9fc9a82853d0aea18cdb905</a>
+<blockquote>
+<p>
+ Fix new logic for skipping clipped image lines.<br>
+<br>
+ In refactoring the previous commit so that it didn't cause<br>
+ diffs, I broke it so that it gave no advantage.<br>
+<br>
+ This version should give no diffs, AND give a speed increase<br>
+ by avoiding unpacking elided lines.<br>
+<br>
+base/gxidata.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-04-03 17:47:03 +0100
+</strong>
+<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=41e94a745cdbed112efc0e72d76645e8500a0791">41e94a745cdbed112efc0e72d76645e8500a0791</a>
+<blockquote>
+<p>
+ Tweak logic for skipping clipped image lines.<br>
+<br>
+ As gs runs through image data, it unpacks each line into<br>
+ a buffer, then checks whether that buffer is trivially<br>
+ outside the clipping region. If it is, then it doesn't<br>
+ bother to call the line renderer.<br>
+<br>
+ This has 2 implications. Firstly, we unpack the line data<br>
+ even if it is to be skipped. Secondly, for line renderers<br>
+ that rely on counting the number of lines they have been<br>
+ passed (rather than on consulting the position of the dda)<br>
+ to know where they are, this can cause problems.<br>
+<br>
+ Accordingly, this commit rejigs the code a bit. As well<br>
+ as a function pointer within penum that points to the<br>
+ rendering routine, we have a new function pointer that<br>
+ points to an optional &quot;skip_render&quot; routine.<br>
+<br>
+ We also rejig the code so that we only unpack the data if<br>
+ we know it is going to be used.<br>
+<br>
+base/gxidata.c<br>
+base/gximage.h<br>
+base/gxipixel.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-04-02 12:43:21 +0100
+</strong>
+<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2870842d23f13413f3492f206cd12bb4144fc80d">2870842d23f13413f3492f206cd12bb4144fc80d</a>
+<blockquote>
+<p>
+ Whitespace fix.<br>
+<br>
+base/gxicolor.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-04-02 12:44:36 +0100
+</strong>
+<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8afca3fad1acbfd34b2a2910d04a5447c2e4555b">8afca3fad1acbfd34b2a2910d04a5447c2e4555b</a>
+<blockquote>
+<p>
+ Downgrade gen_ordered solutions to VS2005.<br>
+<br>
+ From VS2008. VS2008 can still read the new (old!) ones.<br>
+<br>
+toolbin/halftone/gen_ordered/gen_ordered.sln<br>
+toolbin/halftone/gen_ordered/gen_ordered.vcproj<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-04-03 00:13:16 +0100
+</strong>
+<br>Shailesh Mistry &lt;shailesh.mistry@hotmail.co.uk&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7891eda84b33aef5ee7540b3b3d04477e3602a3d">7891eda84b33aef5ee7540b3b3d04477e3602a3d</a>
+<blockquote>
+<p>
+ Prevent SEGV in memento squeeze builds.<br>
+<br>
+ Remove leftover variables from commit 9ff6b34e461fcbd4e.<br>
+ Added conditional compilation to prevent SEGV from thread code.<br>
+<br>
+base/gsicc_cache.c<br>
+base/gsicc_manage.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-03-29 20:15:29 +0100
+</strong>
+<br>Shailesh Mistry &lt;shailesh.mistry@hotmail.co.uk&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f0e234d660dbeb774f39392f0e45e333fd9308a3">f0e234d660dbeb774f39392f0e45e333fd9308a3</a>
+<blockquote>
+<p>
+ Bug 697545 : Update set_cache_device to prevent memory leaks.<br>
+<br>
+ Added a matching grestore for the gsave on all error paths.<br>
+<br>
+base/gxchar.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-03-30 09:21:28 +0100
+</strong>
+<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=bd2ce49067793d8b57c6a1b4831e16f952183f6b">bd2ce49067793d8b57c6a1b4831e16f952183f6b</a>
+<blockquote>
+<p>
+ Address warnings and deprecated API calls.<br>
+<br>
+ A number of gtk/gdk/cairo API calls have been deprecated since GTK+ 3.0 was<br>
+ introduced, and using them triggers warnings - this replaces them with the<br>
+ currently recommended APIs.<br>
+<br>
+ Also fix a couple of regular compiler warnings, and a gsapi related warning.<br>
+<br>
+psi/dxmain.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-03-29 14:04:10 -0700
+</strong>
+<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=25785cd67484e6ebf3625f7d2adedac076e80de2">25785cd67484e6ebf3625f7d2adedac076e80de2</a>
+<blockquote>
+<p>
+ Do not create a new cache for the ICC links with each page in clist mode<br>
+<br>
+ Right now the code currently creates a new ICC cache with every page.<br>
+ This commit maintains the cache and only destroys it when we gdev_prn_tear_down<br>
+<br>
+base/gxclist.c<br>
+base/gxclread.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-03-27 20:13:18 +0100
+</strong>
+<br>Shailesh Mistry &lt;shailesh.mistry@hotmail.co.uk&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=344db7fb39f457201f243b2775e3d63cf8406010">344db7fb39f457201f243b2775e3d63cf8406010</a>
+<blockquote>
+<p>
+ Bug 697545 : Update functions to return error codes.<br>
+<br>
+ Prevent numerous SEGV points by ensuring error codes are returned and<br>
+ handled appropriately.<br>
+<br>
+base/gsdps1.c<br>
+base/gxchar.c<br>
+base/gxifast.c<br>
+base/gximage4.c<br>
+pcl/pcl/pctext.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-03-29 10:14:22 -0700
+</strong>
+<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0f6ec1c44bb38175344be16d747b8feee35ae35f">0f6ec1c44bb38175344be16d747b8feee35ae35f</a>
+<blockquote>
+<p>
+ Memento: Fix typo in Mutex init.<br>
+<br>
+ Thanks to Shelly for pointing this out.<br>
+<br>
+base/memento.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-03-28 14:57:56 +0100
+</strong>
+<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a31ccd111b6ff21a1e49806c1e6e0861a9e45446">a31ccd111b6ff21a1e49806c1e6e0861a9e45446</a>
+<blockquote>
+<p>
+ Update OpenJPEG to 2.3.0<br>
+<br>
+ Incorporates changes from:<br>
+ 1) Add predefined openjpeg headers.<br>
+ 71242c9a04bb76b8b17fc489d62a91d04c1ad60c<br>
+<br>
+ 2) Import patches from Sumatra's tree.<br>
+ 8b89e4b5750069172522ecf85e69d094b5e567e7<br>
+<br>
+ 3) Avoid getenv call in openjpeg<br>
+ 202a0318a7b3a397fcd5d015dcad4293474f464c<br>
+<br>
+base/openjpeg.mak<br>
+openjpeg/CHANGELOG.md<br>
+openjpeg/NEWS.md<br>
+openjpeg/README.md<br>
+openjpeg/appveyor.yml<br>
+openjpeg/doc/CMakeLists.txt<br>
+openjpeg/doc/Doxyfile.dox.cmake.in<br>
+openjpeg/doc/jpip_architect.png<br>
+openjpeg/doc/jpip_protocol.png<br>
+openjpeg/doc/mainpage.dox.in<br>
+openjpeg/doc/man/man1/opj_compress.1<br>
+openjpeg/doc/man/man1/opj_decompress.1<br>
+openjpeg/doc/man/man1/opj_dump.1<br>
+openjpeg/doc/man/man3/libopenjp2.3<br>
+openjpeg/doc/openjpip.dox.in<br>
+openjpeg/src/bin/CMakeLists.txt<br>
+openjpeg/src/bin/common/CMakeLists.txt<br>
+openjpeg/src/bin/common/color.c<br>
+openjpeg/src/bin/common/color.h<br>
+openjpeg/src/bin/common/format_defs.h<br>
+openjpeg/src/bin/common/opj_apps_config.h.cmake.in<br>
+openjpeg/src/bin/common/opj_getopt.c<br>
+openjpeg/src/bin/common/opj_getopt.h<br>
+openjpeg/src/bin/common/opj_string.h<br>
+openjpeg/src/bin/jp2/CMakeLists.txt<br>
+openjpeg/src/bin/jp2/convert.c<br>
+openjpeg/src/bin/jp2/convert.h<br>
+openjpeg/src/bin/jp2/convertbmp.c<br>
+openjpeg/src/bin/jp2/convertpng.c<br>
+openjpeg/src/bin/jp2/converttif.c<br>
+openjpeg/src/bin/jp2/index.c<br>
+openjpeg/src/bin/jp2/index.h<br>
+openjpeg/src/bin/jp2/opj_compress.c<br>
+openjpeg/src/bin/jp2/opj_decompress.c<br>
+openjpeg/src/bin/jp2/opj_dump.c<br>
+openjpeg/src/bin/jp2/windirent.h<br>
+openjpeg/src/bin/jp3d/CMakeLists.txt<br>
+openjpeg/src/bin/jp3d/convert.c<br>
+openjpeg/src/bin/jp3d/convert.h<br>
+openjpeg/src/bin/jp3d/getopt.c<br>
+openjpeg/src/bin/jp3d/getopt.h<br>
+openjpeg/src/bin/jp3d/opj_jp3d_compress.c<br>
+openjpeg/src/bin/jp3d/opj_jp3d_decompress.c<br>
+openjpeg/src/bin/jp3d/tcltk/LPI_JP3D_VM.tcl<br>
+openjpeg/src/bin/jp3d/tcltk/README<br>
+openjpeg/src/bin/jp3d/tcltk/Thumbs.db<br>
+openjpeg/src/bin/jp3d/tcltk/decoder.tcl<br>
+openjpeg/src/bin/jp3d/tcltk/encoder.tcl<br>
+openjpeg/src/bin/jp3d/tcltk/logoLPI.gif<br>
+openjpeg/src/bin/jp3d/windirent.h<br>
+openjpeg/src/bin/jpip/CMakeLists.txt<br>
+openjpeg/src/bin/jpip/README<br>
+openjpeg/src/bin/jpip/opj_dec_server.c<br>
+openjpeg/src/bin/jpip/opj_jpip_addxml.c<br>
+openjpeg/src/bin/jpip/opj_jpip_test.c<br>
+openjpeg/src/bin/jpip/opj_jpip_transcode.c<br>
+openjpeg/src/bin/jpip/opj_server.c<br>
+openjpeg/src/bin/jpip/opj_viewer/dist/manifest.txt<br>
+openjpeg/src/bin/jpip/opj_viewer/src/ImageManager.java<br>
+openjpeg/src/bin/jpip/opj_viewer/src/ImageViewer.java<br>
+openjpeg/src/bin/jpip/opj_viewer/src/ImageWindow.java<br>
+openjpeg/src/bin/jpip/opj_viewer/src/ImgdecClient.java<br>
+openjpeg/src/bin/jpip/opj_viewer/src/JPIPHttpClient.java<br>
+openjpeg/src/bin/jpip/opj_viewer/src/MML.java<br>
+openjpeg/src/bin/jpip/opj_viewer/src/PnmImage.java<br>
+openjpeg/src/bin/jpip/opj_viewer/src/RegimViewer.java<br>
+openjpeg/src/bin/jpip/opj_viewer/src/ResizeListener.java<br>
+openjpeg/src/bin/jpip/opj_viewer_xerces/dist/manifest.txt.in<br>
+openjpeg/src/bin/jpip/opj_viewer_xerces/src/ImageViewer.java<br>
+openjpeg/src/bin/jpip/opj_viewer_xerces/src/ImageWindow.java<br>
+openjpeg/src/bin/jpip/opj_viewer_xerces/src/JP2XMLparser.java<br>
+openjpeg/src/bin/jpip/opj_viewer_xerces/src/OptionPanel.java<br>
+openjpeg/src/bin/jpwl/CMakeLists.txt<br>
+openjpeg/src/bin/jpwl/convert.c<br>
+openjpeg/src/bin/jpwl/convert.h<br>
+openjpeg/src/bin/jpwl/index.c<br>
+openjpeg/src/bin/jpwl/index.h<br>
+openjpeg/src/bin/jpwl/opj_jpwl_compress.c<br>
+openjpeg/src/bin/jpwl/opj_jpwl_decompress.c<br>
+openjpeg/src/bin/jpwl/windirent.h<br>
+openjpeg/src/bin/mj2/CMakeLists.txt<br>
+openjpeg/src/bin/mj2/meta_out.c<br>
+openjpeg/src/bin/mj2/meta_out.h<br>
+openjpeg/src/bin/mj2/mj2_to_metadata.c<br>
+openjpeg/src/bin/mj2/mj2_to_metadata.dtd<br>
+openjpeg/src/bin/mj2/mj2_to_metadata.h<br>
+openjpeg/src/bin/mj2/mj2_to_metadata.sln<br>
+openjpeg/src/bin/mj2/mj2_to_metadata.vcproj<br>
+openjpeg/src/bin/mj2/mj2_to_metadata_Notes.doc<br>
+openjpeg/src/bin/mj2/opj_mj2_compress.c<br>
+openjpeg/src/bin/mj2/opj_mj2_decompress.c<br>
+openjpeg/src/bin/mj2/opj_mj2_extract.c<br>
+openjpeg/src/bin/mj2/opj_mj2_wrap.c<br>
+openjpeg/src/bin/mj2/readme.txt<br>
+openjpeg/src/bin/wx/CMakeLists.txt<br>
+openjpeg/src/bin/wx/OPJViewer/CMakeLists.txt<br>
+openjpeg/src/bin/wx/OPJViewer/OPJViewer.iss<br>
+openjpeg/src/bin/wx/OPJViewer/Readme.txt<br>
+openjpeg/src/bin/wx/OPJViewer/about/about.htm<br>
+openjpeg/src/bin/wx/OPJViewer/about/opj_logo.png<br>
+openjpeg/src/bin/wx/OPJViewer/source/OPJAbout.cpp<br>
+openjpeg/src/bin/wx/OPJViewer/source/OPJChild.ico<br>
+openjpeg/src/bin/wx/OPJViewer/source/OPJChild16.xpm<br>
+openjpeg/src/bin/wx/OPJViewer/source/OPJDialogs.cpp<br>
+openjpeg/src/bin/wx/OPJViewer/source/OPJThreads.cpp<br>
+openjpeg/src/bin/wx/OPJViewer/source/OPJViewer.cpp<br>
+openjpeg/src/bin/wx/OPJViewer/source/OPJViewer.h<br>
+openjpeg/src/bin/wx/OPJViewer/source/OPJViewer.ico<br>
+openjpeg/src/bin/wx/OPJViewer/source/OPJViewer.rc<br>
+openjpeg/src/bin/wx/OPJViewer/source/OPJViewer16.xpm<br>
+openjpeg/src/bin/wx/OPJViewer/source/about_htm.h<br>
+openjpeg/src/bin/wx/OPJViewer/source/build.h<br>
+openjpeg/src/bin/wx/OPJViewer/source/icon1.xpm<br>
+openjpeg/src/bin/wx/OPJViewer/source/icon2.xpm<br>
+openjpeg/src/bin/wx/OPJViewer/source/icon3.xpm<br>
+openjpeg/src/bin/wx/OPJViewer/source/icon4.xpm<br>
+openjpeg/src/bin/wx/OPJViewer/source/icon5.xpm<br>
+openjpeg/src/bin/wx/OPJViewer/source/imagjpeg2000.cpp<br>
+openjpeg/src/bin/wx/OPJViewer/source/imagjpeg2000.h<br>
+openjpeg/src/bin/wx/OPJViewer/source/imagmxf.cpp<br>
+openjpeg/src/bin/wx/OPJViewer/source/imagmxf.h<br>
+openjpeg/src/bin/wx/OPJViewer/source/license.txt<br>
+openjpeg/src/bin/wx/OPJViewer/source/opj_logo.xpm<br>
+openjpeg/src/bin/wx/OPJViewer/source/readmeafter.txt<br>
+openjpeg/src/bin/wx/OPJViewer/source/readmebefore.txt<br>
+openjpeg/src/bin/wx/OPJViewer/source/wxj2kparser.cpp<br>
+openjpeg/src/bin/wx/OPJViewer/source/wxjp2parser.cpp<br>
+openjpeg/src/lib/openjp2/CMakeLists.txt<br>
+openjpeg/src/lib/openjp2/bench_dwt.c<br>
+openjpeg/src/lib/openjp2/dwt.c<br>
+openjpeg/src/lib/openjp2/dwt.h<br>
+openjpeg/src/lib/openjp2/image.c<br>
+openjpeg/src/lib/openjp2/j2k.c<br>
+openjpeg/src/lib/openjp2/j2k.h<br>
+openjpeg/src/lib/openjp2/jp2.c<br>
+openjpeg/src/lib/openjp2/jp2.h<br>
+openjpeg/src/lib/openjp2/mct.c<br>
+openjpeg/src/lib/openjp2/mct.h<br>
+openjpeg/src/lib/openjp2/mqc.c<br>
+openjpeg/src/lib/openjp2/mqc.h<br>
+openjpeg/src/lib/openjp2/mqc_inl.h<br>
+openjpeg/src/lib/openjp2/openjpeg.c<br>
+openjpeg/src/lib/openjp2/openjpeg.h<br>
+openjpeg/src/lib/openjp2/opj_codec.h<br>
+openjpeg/src/lib/openjp2/opj_config.h<br>
+openjpeg/src/lib/openjp2/opj_config_private.h<br>
+openjpeg/src/lib/openjp2/opj_includes.h<br>
+openjpeg/src/lib/openjp2/opj_intmath.h<br>
+openjpeg/src/lib/openjp2/sparse_array.c<br>
+openjpeg/src/lib/openjp2/sparse_array.h<br>
+openjpeg/src/lib/openjp2/t1.c<br>
+openjpeg/src/lib/openjp2/t1.h<br>
+openjpeg/src/lib/openjp2/t2.c<br>
+openjpeg/src/lib/openjp2/t2.h<br>
+openjpeg/src/lib/openjp2/tcd.c<br>
+openjpeg/src/lib/openjp2/tcd.h<br>
+openjpeg/src/lib/openjp2/test_sparse_array.c<br>
+openjpeg/src/lib/openjp2/thread.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-03-27 16:26:13 +0100
+</strong>
+<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=25971c91d6433b0249d3b721b75ef704afe0a09c">25971c91d6433b0249d3b721b75ef704afe0a09c</a>
+<blockquote>
+<p>
+ Update libjpeg to 9c<br>
+<br>
+ Plus re-applying:<br>
+ Bug 697186: Workaround JPEG lib bug.<br>
+ 8dcec8cc076a0cf8350ca7a6ec1d3136812e2a24<br>
+<br>
+ Bug 697186: Tweak to previous JPEG fix.<br>
+ dc62c90930512f4b571f68c9110022b234cbd411<br>
+<br>
+jpeg/Makefile.am<br>
+jpeg/Makefile.in<br>
+jpeg/README<br>
+jpeg/aclocal.m4<br>
+jpeg/ar-lib<br>
+jpeg/cderror.h<br>
+jpeg/change.log<br>
+jpeg/cjpeg.1<br>
+jpeg/compile<br>
+jpeg/config.guess<br>
+jpeg/config.sub<br>
+jpeg/configure<br>
+jpeg/configure.ac<br>
+jpeg/depcomp<br>
+jpeg/djpeg.1<br>
+jpeg/djpeg.c<br>
+jpeg/filelist.txt<br>
+jpeg/install-sh<br>
+jpeg/install.txt<br>
+jpeg/jcinit.c<br>
+jpeg/jcmaster.c<br>
+jpeg/jconfig.vc<br>
+jpeg/jcsample.c<br>
+jpeg/jctrans.c<br>
+jpeg/jdarith.c<br>
+jpeg/jdatadst.c<br>
+jpeg/jdatasrc.c<br>
+jpeg/jdcolor.c<br>
+jpeg/jdct.h<br>
+jpeg/jdhuff.c<br>
+jpeg/jdmainct.c<br>
+jpeg/jdmaster.c<br>
+jpeg/jdmerge.c<br>
+jpeg/jdsample.c<br>
+jpeg/jerror.c<br>
+jpeg/jfdctflt.c<br>
+jpeg/jfdctfst.c<br>
+jpeg/jfdctint.c<br>
+jpeg/jidctflt.c<br>
+jpeg/jidctfst.c<br>
+jpeg/jidctint.c<br>
+jpeg/jinclude.h<br>
+jpeg/jpegint.h<br>
+jpeg/jpeglib.h<br>
+jpeg/jpegtran.1<br>
+jpeg/jversion.h<br>
+jpeg/libjpeg.pc.in<br>
+jpeg/ltmain.sh<br>
+jpeg/makeasln.v15<br>
+jpeg/makecfil.v15<br>
+jpeg/makecvcx.v15<br>
+jpeg/makedfil.v15<br>
+jpeg/makedvcx.v15<br>
+jpeg/makefile.ansi<br>
+jpeg/makefile.b32<br>
+jpeg/makefile.bcc<br>
+jpeg/makefile.dj<br>
+jpeg/makefile.manx<br>
+jpeg/makefile.mc6<br>
+jpeg/makefile.mms<br>
+jpeg/makefile.sas<br>
+jpeg/makefile.unix<br>
+jpeg/makefile.vc<br>
+jpeg/makefile.vs<br>
+jpeg/makefile.wat<br>
+jpeg/makejfil.v15<br>
+jpeg/makejsln.v15<br>
+jpeg/makejvcx.v15<br>
+jpeg/makerfil.v15<br>
+jpeg/makervcx.v15<br>
+jpeg/maketfil.v15<br>
+jpeg/maketvcx.v15<br>
+jpeg/makewfil.v15<br>
+jpeg/makewvcx.v15<br>
+jpeg/missing<br>
+jpeg/rdbmp.c<br>
+jpeg/rdppm.c<br>
+jpeg/rdswitch.c<br>
+jpeg/rdtarga.c<br>
+jpeg/transupp.c<br>
+jpeg/usage.txt<br>
+jpeg/wrbmp.c<br>
+jpeg/wrgif.c<br>
+jpeg/wrjpgcom.c<br>
+jpeg/wrppm.c<br>
+jpeg/wrrle.c<br>
+jpeg/wrtarga.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-03-27 16:16:49 +0100
+</strong>
+<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d8a919d4b45097a527f6f39d509b920d285d709b">d8a919d4b45097a527f6f39d509b920d285d709b</a>
+<blockquote>
+<p>
+ Update expat to 2.2.5<br>
+<br>
+ With a couple of tweaks to base/expat.mak to make it work.<br>
+<br>
+base/expat.mak<br>
+expat/AUTHORS<br>
+expat/CMake.README<br>
+expat/CMakeLists.txt<br>
+expat/COPYING<br>
+expat/Changes<br>
+expat/ConfigureChecks.cmake<br>
+expat/MANIFEST<br>
+expat/Makefile.am<br>
+expat/Makefile.in<br>
+expat/README<br>
+expat/README.md<br>
+expat/aclocal.m4<br>
+expat/amiga/Makefile<br>
+expat/amiga/README.txt<br>
+expat/amiga/expat.xml<br>
+expat/amiga/expat_68k.c<br>
+expat/amiga/expat_68k.h<br>
+expat/amiga/expat_68k_handler_stubs.c<br>
+expat/amiga/expat_base.h<br>
+expat/amiga/expat_lib.c<br>
+expat/amiga/expat_vectors.c<br>
+expat/amiga/include/inline4/expat.h<br>
+expat/amiga/include/interfaces/expat.h<br>
+expat/amiga/include/libraries/expat.h<br>
+expat/amiga/include/proto/expat.h<br>
+expat/amiga/launch.c<br>
+expat/bcb5/README.txt<br>
+expat/bcb5/all_projects.bpg<br>
+expat/bcb5/elements.bpf<br>
+expat/bcb5/elements.bpr<br>
+expat/bcb5/elements.mak<br>
+expat/bcb5/expat.bpf<br>
+expat/bcb5/expat.bpr<br>
+expat/bcb5/expat.mak<br>
+expat/bcb5/expat_static.bpf<br>
+expat/bcb5/expat_static.bpr<br>
+expat/bcb5/expat_static.mak<br>
+expat/bcb5/expatw.bpf<br>
+expat/bcb5/expatw.bpr<br>
+expat/bcb5/expatw.mak<br>
+expat/bcb5/expatw_static.bpf<br>
+expat/bcb5/expatw_static.bpr<br>
+expat/bcb5/expatw_static.mak<br>
+expat/bcb5/libexpat_mtd.def<br>
+expat/bcb5/libexpatw_mtd.def<br>
+expat/bcb5/makefile.mak<br>
+expat/bcb5/outline.bpf<br>
+expat/bcb5/outline.bpr<br>
+expat/bcb5/outline.mak<br>
+expat/bcb5/setup.bat<br>
+expat/bcb5/xmlwf.bpf<br>
+expat/bcb5/xmlwf.bpr<br>
+expat/bcb5/xmlwf.mak<br>
+expat/configure<br>
+expat/configure.ac<br>
+expat/conftools/compile<br>
+expat/conftools/config.guess<br>
+expat/conftools/config.sub<br>
+expat/conftools/depcomp<br>
+expat/conftools/get-version.sh<br>
+expat/conftools/install-sh<br>
+expat/conftools/missing<br>
+expat/conftools/mkinstalldirs<br>
+expat/conftools/test-driver<br>
+expat/doc/Makefile.am<br>
+expat/doc/Makefile.in<br>
+expat/doc/reference.html<br>
+expat/doc/xmlwf.1<br>
+expat/doc/xmlwf.xml<br>
+expat/examples/Makefile.am<br>
+expat/examples/Makefile.in<br>
+expat/examples/elements.c<br>
+expat/examples/elements.dsp<br>
+expat/examples/elements.vcxproj<br>
+expat/examples/elements.vcxproj.filters<br>
+expat/examples/outline.c<br>
+expat/examples/outline.dsp<br>
+expat/examples/outline.vcxproj<br>
+expat/examples/outline.vcxproj.filters<br>
+expat/expat.dsw<br>
+expat/expat.sln<br>
+expat/expat_config.h<br>
+expat/expat_config.h.cmake<br>
+expat/expat_config.h.in<br>
+expat/lib/Makefile.MPW<br>
+expat/lib/Makefile.am<br>
+expat/lib/Makefile.in<br>
+expat/lib/amigaconfig.h<br>
+expat/lib/ascii.h<br>
+expat/lib/asciitab.h<br>
+expat/lib/expat.dsp<br>
+expat/lib/expat.h<br>
+expat/lib/expat.vcxproj<br>
+expat/lib/expat.vcxproj.filters<br>
+expat/lib/expat_external.h<br>
+expat/lib/expat_static.dsp<br>
+expat/lib/expat_static.vcxproj<br>
+expat/lib/expat_static.vcxproj.filters<br>
+expat/lib/expatw.dsp<br>
+expat/lib/expatw.vcxproj<br>
+expat/lib/expatw.vcxproj.filters<br>
+expat/lib/expatw_static.dsp<br>
+expat/lib/expatw_static.vcxproj<br>
+expat/lib/expatw_static.vcxproj.filters<br>
+expat/lib/iasciitab.h<br>
+expat/lib/internal.h<br>
+expat/lib/latin1tab.h<br>
+expat/lib/libexpat.def<br>
+expat/lib/libexpatw.def<br>
+expat/lib/loadlibrary.c<br>
+expat/lib/macconfig.h<br>
+expat/lib/nametab.h<br>
+expat/lib/siphash.h<br>
+expat/lib/utf8tab.h<br>
+expat/lib/winconfig.h<br>
+expat/lib/xmlparse.c<br>
+expat/lib/xmlrole.c<br>
+expat/lib/xmlrole.h<br>
+expat/lib/xmltok.c<br>
+expat/lib/xmltok.h<br>
+expat/lib/xmltok_impl.c<br>
+expat/lib/xmltok_impl.h<br>
+expat/lib/xmltok_ns.c<br>
+expat/m4/libtool.m4<br>
+expat/run.sh.in<br>
+expat/test-driver-wrapper.sh<br>
+expat/tests/Makefile.am<br>
+expat/tests/Makefile.in<br>
+expat/tests/benchmark/Makefile.am<br>
+expat/tests/benchmark/Makefile.in<br>
+expat/tests/benchmark/benchmark.c<br>
+expat/tests/benchmark/benchmark.dsp<br>
+expat/tests/benchmark/benchmark.dsw<br>
+expat/tests/benchmark/benchmark.sln<br>
+expat/tests/benchmark/benchmark.vcxproj<br>
+expat/tests/chardata.c<br>
+expat/tests/chardata.h<br>
+expat/tests/memcheck.c<br>
+expat/tests/memcheck.h<br>
+expat/tests/minicheck.c<br>
+expat/tests/minicheck.h<br>
+expat/tests/runtests.c<br>
+expat/tests/runtests.sln<br>
+expat/tests/runtests.vcxproj<br>
+expat/tests/runtests.vcxproj.filters<br>
+expat/tests/runtestspp.cpp<br>
+expat/tests/structdata.c<br>
+expat/tests/structdata.h<br>
+expat/tests/udiffer.py<br>
+expat/tests/xmltest.log.expected<br>
+expat/tests/xmltest.sh<br>
+expat/vms/README.vms<br>
+expat/vms/descrip.mms<br>
+expat/vms/expat_config.h<br>
+expat/win32/MANIFEST.txt<br>
+expat/win32/README.txt<br>
+expat/win32/expat.iss<br>
+expat/xmlwf/Makefile.am<br>
+expat/xmlwf/Makefile.in<br>
+expat/xmlwf/codepage.c<br>
+expat/xmlwf/codepage.h<br>
+expat/xmlwf/ct.c<br>
+expat/xmlwf/filemap.h<br>
+expat/xmlwf/readfilemap.c<br>
+expat/xmlwf/unixfilemap.c<br>
+expat/xmlwf/win32filemap.c<br>
+expat/xmlwf/xmlfile.c<br>
+expat/xmlwf/xmlfile.h<br>
+expat/xmlwf/xmlmime.c<br>
+expat/xmlwf/xmlmime.h<br>
+expat/xmlwf/xmltchar.h<br>
+expat/xmlwf/xmlurl.h<br>
+expat/xmlwf/xmlwf.c<br>
+expat/xmlwf/xmlwf.dsp<br>
+expat/xmlwf/xmlwf.vcxproj<br>
+expat/xmlwf/xmlwf.vcxproj.filters<br>
+expat/xmlwf/xmlwin32url.cxx<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-03-27 14:08:47 +0100
+</strong>
+<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=003c4211a019eb5c4719860f353777e177553490">003c4211a019eb5c4719860f353777e177553490</a>
+<blockquote>
+<p>
+ Update libtiff to 4.0.9<br>
+<br>
+ Add in portability changes to tiffiop.h<br>
+<br>
+ Portability tiffiop.h<br>
+<br>
+ Remove globals from tif_pixarlog.c<br>
+<br>
+ Tweaks to support libtiff 4.0.9<br>
+<br>
+base/gstiffio.c<br>
+configure.ac<br>
+tiff/CMakeLists.txt<br>
+tiff/ChangeLog<br>
+tiff/HOWTO-RELEASE<br>
+tiff/RELEASE-DATE<br>
+tiff/VERSION<br>
+tiff/config/ltmain.sh<br>
+tiff/configure<br>
+tiff/configure.ac<br>
+tiff/html/Makefile.am<br>
+tiff/html/Makefile.in<br>
+tiff/html/index.html<br>
+tiff/html/man/CMakeLists.txt<br>
+tiff/html/man/Makefile.am<br>
+tiff/html/man/Makefile.in<br>
+tiff/html/man/rgb2ycbcr.1.html<br>
+tiff/html/man/thumbnail.1.html<br>
+tiff/html/v4.0.7.html<br>
+tiff/html/v4.0.8.html<br>
+tiff/html/v4.0.9.html<br>
+tiff/libtiff/libtiff.def<br>
+tiff/libtiff/tif_aux.c<br>
+tiff/libtiff/tif_color.c<br>
+tiff/libtiff/tif_dir.c<br>
+tiff/libtiff/tif_dir.h<br>
+tiff/libtiff/tif_dirinfo.c<br>
+tiff/libtiff/tif_dirread.c<br>
+tiff/libtiff/tif_dirwrite.c<br>
+tiff/libtiff/tif_error.c<br>
+tiff/libtiff/tif_fax3.c<br>
+tiff/libtiff/tif_fax3.h<br>
+tiff/libtiff/tif_getimage.c<br>
+tiff/libtiff/tif_jbig.c<br>
+tiff/libtiff/tif_jpeg.c<br>
+tiff/libtiff/tif_jpeg_12.c<br>
+tiff/libtiff/tif_luv.c<br>
+tiff/libtiff/tif_lzw.c<br>
+tiff/libtiff/tif_ojpeg.c<br>
+tiff/libtiff/tif_open.c<br>
+tiff/libtiff/tif_packbits.c<br>
+tiff/libtiff/tif_pixarlog.c<br>
+tiff/libtiff/tif_predict.c<br>
+tiff/libtiff/tif_print.c<br>
+tiff/libtiff/tif_read.c<br>
+tiff/libtiff/tif_strip.c<br>
+tiff/libtiff/tif_swab.c<br>
+tiff/libtiff/tif_unix.c<br>
+tiff/libtiff/tif_warning.c<br>
+tiff/libtiff/tif_win32.c<br>
+tiff/libtiff/tif_write.c<br>
+tiff/libtiff/tif_zip.c<br>
+tiff/libtiff/tiffio.h<br>
+tiff/libtiff/tiffiop.h<br>
+tiff/libtiff/tiffvers.h<br>
+tiff/m4/libtool.m4<br>
+tiff/man/CMakeLists.txt<br>
+tiff/man/Makefile.am<br>
+tiff/man/Makefile.in<br>
+tiff/man/TIFFGetField.3tiff<br>
+tiff/man/TIFFSetDirectory.3tiff<br>
+tiff/man/TIFFSetField.3tiff<br>
+tiff/man/rgb2ycbcr.1<br>
+tiff/man/thumbnail.1<br>
+tiff/nmake.opt<br>
+tiff/test/CMakeLists.txt<br>
+tiff/test/Makefile.am<br>
+tiff/test/Makefile.in<br>
+tiff/test/TiffTestCommon.cmake<br>
+tiff/test/common.sh<br>
+tiff/test/images/quad-lzw-compat.tiff<br>
+tiff/test/tiff2bw-palette-1c-8b.sh<br>
+tiff/test/tiff2bw-quad-lzw-compat.sh<br>
+tiff/test/tiff2bw-rgb-3c-8b.sh<br>
+tiff/test/tiffcp-lzw-compat.sh<br>
+tiff/tools/fax2tiff.c<br>
+tiff/tools/raw2tiff.c<br>
+tiff/tools/tiff2bw.c<br>
+tiff/tools/tiff2pdf.c<br>
+tiff/tools/tiff2ps.c<br>
+tiff/tools/tiffcp.c<br>
+tiff/tools/tiffcrop.c<br>
+tiff/tools/tiffinfo.c<br>
+tiff/tools/tiffset.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-03-26 16:12:39 +0100
+</strong>
+<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=bc817a3afdb932eadac17155834f89efd1c96da4">bc817a3afdb932eadac17155834f89efd1c96da4</a>
+<blockquote>
+<p>
+ Bring libpng up to 1.6.34<br>
+<br>
+base/png.mak<br>
+libpng/ANNOUNCE<br>
+libpng/CHANGES<br>
+libpng/CMakeLists.txt<br>
+libpng/INSTALL<br>
+libpng/LICENSE<br>
+libpng/Makefile.am<br>
+libpng/Makefile.in<br>
+libpng/README<br>
+libpng/TODO<br>
+libpng/arm/filter_neon.S<br>
+libpng/config.h.in<br>
+libpng/configure<br>
+libpng/configure.ac<br>
+libpng/contrib/arm-neon/android-ndk.c<br>
+libpng/contrib/arm-neon/linux.c<br>
+libpng/contrib/examples/pngtopng.c<br>
+libpng/contrib/gregbook/README<br>
+libpng/contrib/gregbook/readpng.c<br>
+libpng/contrib/gregbook/readpng2.c<br>
+libpng/contrib/gregbook/readppm.c<br>
+libpng/contrib/gregbook/rpng-win.c<br>
+libpng/contrib/gregbook/rpng-x.c<br>
+libpng/contrib/gregbook/rpng2-win.c<br>
+libpng/contrib/gregbook/rpng2-x.c<br>
+libpng/contrib/gregbook/wpng.c<br>
+libpng/contrib/gregbook/writepng.c<br>
+libpng/contrib/intel/INSTALL<br>
+libpng/contrib/intel/intel_sse.patch<br>
+libpng/contrib/libtests/pngstest.c<br>
+libpng/contrib/libtests/pngunknown.c<br>
+libpng/contrib/libtests/pngvalid.c<br>
+libpng/contrib/oss-fuzz/Dockerfile<br>
+libpng/contrib/oss-fuzz/README.txt<br>
+libpng/contrib/oss-fuzz/build.sh<br>
+libpng/contrib/oss-fuzz/libpng_read_fuzzer.cc<br>
+libpng/contrib/oss-fuzz/libpng_read_fuzzer.options<br>
+libpng/contrib/oss-fuzz/newcc<br>
+libpng/contrib/oss-fuzz/png.dict<br>
+libpng/contrib/pngminus/png2pnm.c<br>
+libpng/contrib/pngminus/pnm2png.c<br>
+libpng/contrib/powerpc-vsx/README<br>
+libpng/contrib/powerpc-vsx/linux.c<br>
+libpng/contrib/powerpc-vsx/linux_aux.c<br>
+libpng/contrib/testpngs/crashers/bad_iCCP.png<br>
+libpng/contrib/testpngs/crashers/badadler.png<br>
+libpng/contrib/testpngs/crashers/badcrc.png<br>
+libpng/contrib/testpngs/crashers/empty_ancillary_chunks.png<br>
+libpng/contrib/testpngs/crashers/huge_IDAT.png<br>
+libpng/contrib/testpngs/crashers/huge_bKGD_chunk.png<br>
+libpng/contrib/testpngs/crashers/huge_cHRM_chunk.png<br>
+libpng/contrib/testpngs/crashers/huge_eXIf_chunk.png<br>
+libpng/contrib/testpngs/crashers/huge_gAMA_chunk.png<br>
+libpng/contrib/testpngs/crashers/huge_hIST_chunk.png<br>
+libpng/contrib/testpngs/crashers/huge_iCCP_chunk.png<br>
+libpng/contrib/testpngs/crashers/huge_iTXt_chunk.png<br>
+libpng/contrib/testpngs/crashers/huge_juNK_unsafe_to_copy.png<br>
+libpng/contrib/testpngs/crashers/huge_juNk_safe_to_copy.png<br>
+libpng/contrib/testpngs/crashers/huge_pCAL_chunk.png<br>
+libpng/contrib/testpngs/crashers/huge_pHYs_chunk.png<br>
+libpng/contrib/testpngs/crashers/huge_sCAL_chunk.png<br>
+libpng/contrib/testpngs/crashers/huge_sPLT_chunk.png<br>
+libpng/contrib/testpngs/crashers/huge_sRGB_chunk.png<br>
+libpng/contrib/testpngs/crashers/huge_sTER_chunk.png<br>
+libpng/contrib/testpngs/crashers/huge_tEXt_chunk.png<br>
+libpng/contrib/testpngs/crashers/huge_tIME_chunk.png<br>
+libpng/contrib/testpngs/crashers/huge_zTXt_chunk.png<br>
+libpng/contrib/testpngs/gray-1-1.8-tRNS.png<br>
+libpng/contrib/testpngs/gray-1-1.8.png<br>
+libpng/contrib/testpngs/gray-1-linear-tRNS.png<br>
+libpng/contrib/testpngs/gray-1-linear.png<br>
+libpng/contrib/testpngs/gray-1-sRGB-tRNS.png<br>
+libpng/contrib/testpngs/gray-1-sRGB.png<br>
+libpng/contrib/testpngs/gray-1-tRNS.png<br>
+libpng/contrib/testpngs/gray-1.png<br>
+libpng/contrib/testpngs/gray-16-1.8-tRNS.png<br>
+libpng/contrib/testpngs/gray-16-1.8.png<br>
+libpng/contrib/testpngs/gray-16-linear-tRNS.png<br>
+libpng/contrib/testpngs/gray-16-linear.png<br>
+libpng/contrib/testpngs/gray-16-sRGB-tRNS.png<br>
+libpng/contrib/testpngs/gray-16-sRGB.png<br>
+libpng/contrib/testpngs/gray-16-tRNS.png<br>
+libpng/contrib/testpngs/gray-16.png<br>
+libpng/contrib/testpngs/gray-2-1.8-tRNS.png<br>
+libpng/contrib/testpngs/gray-2-1.8.png<br>
+libpng/contrib/testpngs/gray-2-linear-tRNS.png<br>
+libpng/contrib/testpngs/gray-2-linear.png<br>
+libpng/contrib/testpngs/gray-2-sRGB-tRNS.png<br>
+libpng/contrib/testpngs/gray-2-sRGB.png<br>
+libpng/contrib/testpngs/gray-2-tRNS.png<br>
+libpng/contrib/testpngs/gray-2.png<br>
+libpng/contrib/testpngs/gray-4-1.8-tRNS.png<br>
+libpng/contrib/testpngs/gray-4-1.8.png<br>
+libpng/contrib/testpngs/gray-4-linear-tRNS.png<br>
+libpng/contrib/testpngs/gray-4-linear.png<br>
+libpng/contrib/testpngs/gray-4-sRGB-tRNS.png<br>
+libpng/contrib/testpngs/gray-4-sRGB.png<br>
+libpng/contrib/testpngs/gray-4-tRNS.png<br>
+libpng/contrib/testpngs/gray-4.png<br>
+libpng/contrib/testpngs/gray-8-1.8-tRNS.png<br>
+libpng/contrib/testpngs/gray-8-1.8.png<br>
+libpng/contrib/testpngs/gray-8-linear-tRNS.png<br>
+libpng/contrib/testpngs/gray-8-linear.png<br>
+libpng/contrib/testpngs/gray-8-sRGB-tRNS.png<br>
+libpng/contrib/testpngs/gray-8-sRGB.png<br>
+libpng/contrib/testpngs/gray-8-tRNS.png<br>
+libpng/contrib/testpngs/gray-8.png<br>
+libpng/contrib/testpngs/gray-alpha-16-1.8.png<br>
+libpng/contrib/testpngs/gray-alpha-16-linear.png<br>
+libpng/contrib/testpngs/gray-alpha-16-sRGB.png<br>
+libpng/contrib/testpngs/gray-alpha-16.png<br>
+libpng/contrib/testpngs/gray-alpha-8-1.8.png<br>
+libpng/contrib/testpngs/gray-alpha-8-linear.png<br>
+libpng/contrib/testpngs/gray-alpha-8-sRGB.png<br>
+libpng/contrib/testpngs/gray-alpha-8.png<br>
+libpng/contrib/testpngs/makepngs.sh<br>
+libpng/contrib/testpngs/palette-1-1.8-tRNS.png<br>
+libpng/contrib/testpngs/palette-1-1.8.png<br>
+libpng/contrib/testpngs/palette-1-linear-tRNS.png<br>
+libpng/contrib/testpngs/palette-1-linear.png<br>
+libpng/contrib/testpngs/palette-1-sRGB-tRNS.png<br>
+libpng/contrib/testpngs/palette-1-sRGB.png<br>
+libpng/contrib/testpngs/palette-1-tRNS.png<br>
+libpng/contrib/testpngs/palette-1.png<br>
+libpng/contrib/testpngs/palette-2-1.8-tRNS.png<br>
+libpng/contrib/testpngs/palette-2-1.8.png<br>
+libpng/contrib/testpngs/palette-2-linear-tRNS.png<br>
+libpng/contrib/testpngs/palette-2-linear.png<br>
+libpng/contrib/testpngs/palette-2-sRGB-tRNS.png<br>
+libpng/contrib/testpngs/palette-2-sRGB.png<br>
+libpng/contrib/testpngs/palette-2-tRNS.png<br>
+libpng/contrib/testpngs/palette-2.png<br>
+libpng/contrib/testpngs/palette-4-1.8-tRNS.png<br>
+libpng/contrib/testpngs/palette-4-1.8.png<br>
+libpng/contrib/testpngs/palette-4-linear-tRNS.png<br>
+libpng/contrib/testpngs/palette-4-linear.png<br>
+libpng/contrib/testpngs/palette-4-sRGB-tRNS.png<br>
+libpng/contrib/testpngs/palette-4-sRGB.png<br>
+libpng/contrib/testpngs/palette-4-tRNS.png<br>
+libpng/contrib/testpngs/palette-4.png<br>
+libpng/contrib/testpngs/palette-8-1.8-tRNS.png<br>
+libpng/contrib/testpngs/palette-8-1.8.png<br>
+libpng/contrib/testpngs/palette-8-linear-tRNS.png<br>
+libpng/contrib/testpngs/palette-8-linear.png<br>
+libpng/contrib/testpngs/palette-8-sRGB-tRNS.png<br>
+libpng/contrib/testpngs/palette-8-sRGB.png<br>
+libpng/contrib/testpngs/palette-8-tRNS.png<br>
+libpng/contrib/testpngs/palette-8.png<br>
+libpng/contrib/testpngs/rgb-16-1.8-tRNS.png<br>
+libpng/contrib/testpngs/rgb-16-1.8.png<br>
+libpng/contrib/testpngs/rgb-16-linear-tRNS.png<br>
+libpng/contrib/testpngs/rgb-16-linear.png<br>
+libpng/contrib/testpngs/rgb-16-sRGB-tRNS.png<br>
+libpng/contrib/testpngs/rgb-16-sRGB.png<br>
+libpng/contrib/testpngs/rgb-16-tRNS.png<br>
+libpng/contrib/testpngs/rgb-16.png<br>
+libpng/contrib/testpngs/rgb-8-1.8-tRNS.png<br>
+libpng/contrib/testpngs/rgb-8-1.8.png<br>
+libpng/contrib/testpngs/rgb-8-linear-tRNS.png<br>
+libpng/contrib/testpngs/rgb-8-linear.png<br>
+libpng/contrib/testpngs/rgb-8-sRGB-tRNS.png<br>
+libpng/contrib/testpngs/rgb-8-sRGB.png<br>
+libpng/contrib/testpngs/rgb-8-tRNS.png<br>
+libpng/contrib/testpngs/rgb-8.png<br>
+libpng/contrib/testpngs/rgb-alpha-16-1.8.png<br>
+libpng/contrib/testpngs/rgb-alpha-16-linear.png<br>
+libpng/contrib/testpngs/rgb-alpha-16-sRGB.png<br>
+libpng/contrib/testpngs/rgb-alpha-16.png<br>
+libpng/contrib/testpngs/rgb-alpha-8-1.8.png<br>
+libpng/contrib/testpngs/rgb-alpha-8-linear.png<br>
+libpng/contrib/testpngs/rgb-alpha-8-sRGB.png<br>
+libpng/contrib/testpngs/rgb-alpha-8.png<br>
+libpng/contrib/tools/genpng.c<br>
+libpng/contrib/tools/pngfix.c<br>
+libpng/contrib/tools/sRGB.h<br>
+libpng/contrib/visupng/PngFile.c<br>
+libpng/contrib/visupng/VisualPng.c<br>
+libpng/example.c<br>
+libpng/intel/filter_sse2_intrinsics.c<br>
+libpng/intel/intel_init.c<br>
+libpng/libpng-manual.txt<br>
+libpng/libpng.3<br>
+libpng/libpng.pc.in<br>
+libpng/libpngpf.3<br>
+libpng/ltmain.sh<br>
+libpng/mips/filter_msa_intrinsics.c<br>
+libpng/mips/mips_init.c<br>
+libpng/png.5<br>
+libpng/png.c<br>
+libpng/png.h<br>
+libpng/pngconf.h<br>
+libpng/pngerror.c<br>
+libpng/pngget.c<br>
+libpng/pnginfo.h<br>
+libpng/pngpread.c<br>
+libpng/pngpriv.h<br>
+libpng/pngread.c<br>
+libpng/pngrtran.c<br>
+libpng/pngrutil.c<br>
+libpng/pngset.c<br>
+libpng/pngstruct.h<br>
+libpng/pngtest.c<br>
+libpng/pngtest.png<br>
+libpng/pngtrans.c<br>
+libpng/pngwrite.c<br>
+libpng/pngwutil.c<br>
+libpng/powerpc/filter_vsx_intrinsics.c<br>
+libpng/powerpc/powerpc_init.c<br>
+libpng/projects/owatcom/pngconfig.mak<br>
+libpng/projects/vstudio/README.txt<br>
+libpng/projects/vstudio/zlib.props<br>
+libpng/scripts/README.txt<br>
+libpng/scripts/def.c<br>
+libpng/scripts/libpng-config-head.in<br>
+libpng/scripts/libpng.pc.in<br>
+libpng/scripts/makefile.cegcc<br>
+libpng/scripts/makefile.linux<br>
+libpng/scripts/makefile.linux-opt<br>
+libpng/scripts/makefile.msys<br>
+libpng/scripts/makefile.ne12bsd<br>
+libpng/scripts/makefile.netbsd<br>
+libpng/scripts/makefile.openbsd<br>
+libpng/scripts/makefile.solaris-x86<br>
+libpng/scripts/pnglibconf.dfa<br>
+libpng/scripts/pnglibconf.h.prebuilt<br>
+libpng/scripts/symbols.def<br>
+libpng/tests/pngimage-full<br>
+libpng/tests/pngimage-quick<br>
+libpng/tests/pngstest<br>
+libpng/tests/pngstest-1.8<br>
+libpng/tests/pngstest-1.8-alpha<br>
+libpng/tests/pngstest-linear<br>
+libpng/tests/pngstest-linear-alpha<br>
+libpng/tests/pngstest-none<br>
+libpng/tests/pngstest-none-alpha<br>
+libpng/tests/pngstest-sRGB<br>
+libpng/tests/pngstest-sRGB-alpha<br>
+libpng/tests/pngtest<br>
+libpng/tests/pngtest-badpngs<br>
+libpng/tests/pngunknown-IDAT<br>
+libpng/tests/pngunknown-discard<br>
+libpng/tests/pngunknown-if-safe<br>
+libpng/tests/pngunknown-sAPI<br>
+libpng/tests/pngunknown-sTER<br>
+libpng/tests/pngunknown-save<br>
+libpng/tests/pngunknown-vpAg<br>
+libpng/tests/pngvalid-gamma-16-to-8<br>
+libpng/tests/pngvalid-gamma-alpha-mode<br>
+libpng/tests/pngvalid-gamma-background<br>
+libpng/tests/pngvalid-gamma-expand16-alpha-mode<br>
+libpng/tests/pngvalid-gamma-expand16-background<br>
+libpng/tests/pngvalid-gamma-expand16-transform<br>
+libpng/tests/pngvalid-gamma-sbit<br>
+libpng/tests/pngvalid-gamma-threshold<br>
+libpng/tests/pngvalid-gamma-transform<br>
+libpng/tests/pngvalid-progressive-interlace-standard<br>
+libpng/tests/pngvalid-progressive-size<br>
+libpng/tests/pngvalid-progressive-standard<br>
+libpng/tests/pngvalid-standard<br>
+libpng/tests/pngvalid-transform<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-03-27 13:47:02 +0100
+</strong>
+<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0a4ef8b01c2ea146b9dce7b80f21f6cd65420099">0a4ef8b01c2ea146b9dce7b80f21f6cd65420099</a>
+<blockquote>
+<p>
+ Remove symlink from docs install.<br>
+<br>
+ For 9.23 we moved the default installation path for the documentation to better<br>
+ fit with &quot;modern&quot; Linux/Unix directory layouts. To minimize upheaval, we<br>
+ included a symlink to the &quot;old&quot;style path.<br>
+<br>
+ Remove that now, as it was only a temporary thing.<br>
+<br>
+base/unixinst.mak<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-03-27 10:43:29 +0100
+</strong>
+<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3de8ff9bc31edb60370e7275a7c35b557737cd84">3de8ff9bc31edb60370e7275a7c35b557737cd84</a>
+<blockquote>
+<p>
+ Improve the configure check for &quot;restrict&quot; keyword<br>
+<br>
+configure.ac<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-03-29 12:41:37 +0200
+</strong>
+<br>Tor Andersson &lt;tor.andersson@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5249489366cfac73e83e529bae06a08ad6703980">5249489366cfac73e83e529bae06a08ad6703980</a>
+<blockquote>
+<p>
+ Clean up the stdint configuration mess.<br>
+<br>
+ Don't require HAVE_STDINT_H to be defined to assume the sane default of<br>
+ including the C standard stdint.h header file.<br>
+<br>
+ Use the configuration defines to include non-standard header files.<br>
+<br>
+ VS 2012 and newer have stdint.h, so use it.<br>
+<br>
+jbig2dec/config_win32.h<br>
+jbig2dec/os_types.h<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-03-29 12:59:58 +0200
+</strong>
+<br>Tor Andersson &lt;tor.andersson@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0cb8374113ae2770464b6ac7462f11f0cc9677ea">0cb8374113ae2770464b6ac7462f11f0cc9677ea</a>
+<blockquote>
+<p>
+ Fix undeclared function warning.<br>
+<br>
+jbig2dec/jbig2_image_png.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-03-29 12:56:07 +0200
+</strong>
+<br>Tor Andersson &lt;tor.andersson@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a8430e881971485fa4a824a3488f79b7ab0abfeb">a8430e881971485fa4a824a3488f79b7ab0abfeb</a>
+<blockquote>
+<p>
+ Fix signed/unsigned comparison warnings.<br>
+<br>
+jbig2dec/Makefile.unix<br>
+jbig2dec/jbig2_huffman.c<br>
+jbig2dec/jbig2_image_png.c<br>
+jbig2dec/jbig2_mmr.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2017-05-19 12:49:15 +0200
+</strong>
+<br>Tor Andersson &lt;tor.andersson@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=15f72a0b272e751ce7147bb0d8179eac68da52b0">15f72a0b272e751ce7147bb0d8179eac68da52b0</a>
+<blockquote>
+<p>
+ xps: Remove needless NULL terminator when parsing abbreviated geometry.<br>
+<br>
+xps/xpspath.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-03-27 21:21:38 -0700
+</strong>
+<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=59d82e831e62bdf2e44331d10c88dd7837429dad">59d82e831e62bdf2e44331d10c88dd7837429dad</a>
+<blockquote>
+<p>
+ Rename lcms2art to lcms2mt, Remove cmsChangeBuffersFormat<br>
+<br>
+ Since cmsChangeBuffersFormat is NOT threadsafe, we want it to remove it<br>
+ so that it would not be part of this package which is inteded for multi-<br>
+ threaded used. The internal use in CreateNamedColorDevicelink was replaced<br>
+ with the appropriate code from the removed function, but that does not<br>
+ cause a thread safety issue since the link returned is new and not shared<br>
+ when the buffer formatters are changed.<br>
+<br>
+ Note: All internal references to lcms2art are replaced with lcms2mt<br>
+<br>
+Makefile.in<br>
+base/gsicc_lcms2mt.c<br>
+base/lcms2mt.mak<br>
+base/lib.mak<br>
+base/msvclib.mak<br>
+base/openvms.mak<br>
+base/ugcclib.mak<br>
+base/unix-gcc.mak<br>
+base/unixansi.mak<br>
+base/winlib.mak<br>
+configure.ac<br>
+lcms2art/include/Makefile.am<br>
+lcms2mt/.travis.yml<br>
+lcms2mt/AUTHORS<br>
+lcms2mt/COPYING<br>
+lcms2mt/ChangeLog<br>
+lcms2mt/INSTALL<br>
+lcms2mt/Lib/BC/BC.txt<br>
+lcms2mt/Lib/MS/MS.TXT<br>
+lcms2mt/Makefile.am<br>
+lcms2mt/Makefile.in<br>
+lcms2mt/Projects/.gitignore<br>
+lcms2mt/Projects/BorlandC_5.5/lcms2.rc<br>
+lcms2mt/Projects/BorlandC_5.5/lcmsdll.lk<br>
+lcms2mt/Projects/BorlandC_5.5/lcmsdll.lst<br>
+lcms2mt/Projects/BorlandC_5.5/mklcmsdll.bat<br>
+lcms2mt/Projects/VC2010/jpegicc/jpegicc.vcxproj<br>
+lcms2mt/Projects/VC2010/jpegicc/jpegicc.vcxproj.filters<br>
+lcms2mt/Projects/VC2010/linkicc/linkicc.vcxproj<br>
+lcms2mt/Projects/VC2010/linkicc/linkicc.vcxproj.filters<br>
+lcms2mt/Projects/VC2010/psicc/psicc.vcxproj<br>
+lcms2mt/Projects/VC2010/psicc/psicc.vcxproj.filters<br>
+lcms2mt/Projects/VC2010/resource.h<br>
+lcms2mt/Projects/VC2010/testbed/testbed.vcxproj<br>
+lcms2mt/Projects/VC2010/testbed/testbed.vcxproj.filters<br>
+lcms2mt/Projects/VC2010/tiffdiff/tiffdiff.vcxproj<br>
+lcms2mt/Projects/VC2010/tiffdiff/tiffdiff.vcxproj.filters<br>
+lcms2mt/Projects/VC2010/tifficc/tifficc.vcxproj<br>
+lcms2mt/Projects/VC2010/tifficc/tifficc.vcxproj.filters<br>
+lcms2mt/Projects/VC2010/transicc/transicc.vcxproj<br>
+lcms2mt/Projects/VC2010/transicc/transicc.vcxproj.filters<br>
+lcms2mt/Projects/VC2012/jpegicc/jpegicc.vcxproj<br>
+lcms2mt/Projects/VC2012/jpegicc/jpegicc.vcxproj.filters<br>
+lcms2mt/Projects/VC2012/lcms2mt.rc<br>
+lcms2mt/Projects/VC2012/lcms2mt.sln<br>
+lcms2mt/Projects/VC2012/lcms2mt_DLL/lcms2mt_DLL.vcxproj<br>
+lcms2mt/Projects/VC2012/lcms2mt_DLL/lcms2mt_DLL.vcxproj.filters<br>
+lcms2mt/Projects/VC2012/lcms2mt_static/lcms2mt_static.vcxproj<br>
+lcms2mt/Projects/VC2012/lcms2mt_static/lcms2mt_static.vcxproj.filters<br>
+lcms2mt/Projects/VC2012/linkicc/linkicc.vcxproj<br>
+lcms2mt/Projects/VC2012/linkicc/linkicc.vcxproj.filters<br>
+lcms2mt/Projects/VC2012/psicc/psicc.vcxproj<br>
+lcms2mt/Projects/VC2012/psicc/psicc.vcxproj.filters<br>
+lcms2mt/Projects/VC2012/resource.h<br>
+lcms2mt/Projects/VC2012/testbed/testbed.vcxproj<br>
+lcms2mt/Projects/VC2012/testbed/testbed.vcxproj.filters<br>
+lcms2mt/Projects/VC2012/tiffdiff/tiffdiff.vcxproj<br>
+lcms2mt/Projects/VC2012/tiffdiff/tiffdiff.vcxproj.filters<br>
+lcms2mt/Projects/VC2012/tifficc/tifficc.vcxproj<br>
+lcms2mt/Projects/VC2012/tifficc/tifficc.vcxproj.filters<br>
+lcms2mt/Projects/VC2012/transicc/transicc.vcxproj<br>
+lcms2mt/Projects/VC2012/transicc/transicc.vcxproj.filters<br>
+lcms2mt/Projects/VC2013/jpegicc/jpegicc.vcxproj<br>
+lcms2mt/Projects/VC2013/jpegicc/jpegicc.vcxproj.filters<br>
+lcms2mt/Projects/VC2013/lcms2mt.rc<br>
+lcms2mt/Projects/VC2013/lcms2mt.sln<br>
+lcms2mt/Projects/VC2013/lcms2mt_DLL/lcms2mt_DLL.vcxproj<br>
+lcms2mt/Projects/VC2013/lcms2mt_DLL/lcms2mt_DLL.vcxproj.filters<br>
+lcms2mt/Projects/VC2013/lcms2mt_static/lcms2mt_static.vcxproj<br>
+lcms2mt/Projects/VC2013/lcms2mt_static/lcms2mt_static.vcxproj.filters<br>
+lcms2mt/Projects/VC2013/linkicc/linkicc.vcxproj<br>
+lcms2mt/Projects/VC2013/linkicc/linkicc.vcxproj.filters<br>
+lcms2mt/Projects/VC2013/psicc/psicc.vcxproj<br>
+lcms2mt/Projects/VC2013/psicc/psicc.vcxproj.filters<br>
+lcms2mt/Projects/VC2013/resource.h<br>
+lcms2mt/Projects/VC2013/testbed/testbed.vcxproj<br>
+lcms2mt/Projects/VC2013/testbed/testbed.vcxproj.filters<br>
+lcms2mt/Projects/VC2013/tiffdiff/tiffdiff.vcxproj<br>
+lcms2mt/Projects/VC2013/tiffdiff/tiffdiff.vcxproj.filters<br>
+lcms2mt/Projects/VC2013/tifficc/tifficc.vcxproj<br>
+lcms2mt/Projects/VC2013/tifficc/tifficc.vcxproj.filters<br>
+lcms2mt/Projects/VC2013/transicc/transicc.vcxproj<br>
+lcms2mt/Projects/VC2013/transicc/transicc.vcxproj.filters<br>
+lcms2mt/Projects/VC2015/jpegicc/jpegicc.vcxproj<br>
+lcms2mt/Projects/VC2015/jpegicc/jpegicc.vcxproj.filters<br>
+lcms2mt/Projects/VC2015/lcms2mt.rc<br>
+lcms2mt/Projects/VC2015/lcms2mt.sln<br>
+lcms2mt/Projects/VC2015/lcms2mt_DLL/lcms2mt_DLL.vcxproj<br>
+lcms2mt/Projects/VC2015/lcms2mt_DLL/lcms2mt_DLL.vcxproj.filters<br>
+lcms2mt/Projects/VC2015/lcms2mt_static/lcms2mt_static.vcxproj<br>
+lcms2mt/Projects/VC2015/lcms2mt_static/lcms2mt_static.vcxproj.filters<br>
+lcms2mt/Projects/VC2015/linkicc/linkicc.vcxproj<br>
+lcms2mt/Projects/VC2015/linkicc/linkicc.vcxproj.filters<br>
+lcms2mt/Projects/VC2015/psicc/psicc.vcxproj<br>
+lcms2mt/Projects/VC2015/psicc/psicc.vcxproj.filters<br>
+lcms2mt/Projects/VC2015/resource.h<br>
+lcms2mt/Projects/VC2015/testbed/testbed.vcxproj<br>
+lcms2mt/Projects/VC2015/testbed/testbed.vcxproj.filters<br>
+lcms2mt/Projects/VC2015/tiffdiff/tiffdiff.vcxproj<br>
+lcms2mt/Projects/VC2015/tiffdiff/tiffdiff.vcxproj.filters<br>
+lcms2mt/Projects/VC2015/tifficc/tifficc.vcxproj<br>
+lcms2mt/Projects/VC2015/tifficc/tifficc.vcxproj.filters<br>
+lcms2mt/Projects/VC2015/transicc/transicc.vcxproj<br>
+lcms2mt/Projects/VC2015/transicc/transicc.vcxproj.filters<br>
+lcms2mt/Projects/VC2017/jpegicc/jpegicc.vcxproj<br>
+lcms2mt/Projects/VC2017/jpegicc/jpegicc.vcxproj.filters<br>
+lcms2mt/Projects/VC2017/lcms2mt.rc<br>
+lcms2mt/Projects/VC2017/lcms2mt.sln<br>
+lcms2mt/Projects/VC2017/lcms2mt_DLL/lcms2mt_DLL.vcxproj<br>
+lcms2mt/Projects/VC2017/lcms2mt_DLL/lcms2mt_DLL.vcxproj.filters<br>
+lcms2mt/Projects/VC2017/lcms2mt_static/lcms2mt_static.vcxproj<br>
+lcms2mt/Projects/VC2017/lcms2mt_static/lcms2mt_static.vcxproj.filters<br>
+lcms2mt/Projects/VC2017/linkicc/linkicc.vcxproj<br>
+lcms2mt/Projects/VC2017/linkicc/linkicc.vcxproj.filters<br>
+lcms2mt/Projects/VC2017/psicc/psicc.vcxproj<br>
+lcms2mt/Projects/VC2017/psicc/psicc.vcxproj.filters<br>
+lcms2mt/Projects/VC2017/resource.h<br>
+lcms2mt/Projects/VC2017/testbed/testbed.vcxproj<br>
+lcms2mt/Projects/VC2017/testbed/testbed.vcxproj.filters<br>
+lcms2mt/Projects/VC2017/tiffdiff/tiffdiff.vcxproj<br>
+lcms2mt/Projects/VC2017/tiffdiff/tiffdiff.vcxproj.filters<br>
+lcms2mt/Projects/VC2017/tifficc/tifficc.vcxproj<br>
+lcms2mt/Projects/VC2017/tifficc/tifficc.vcxproj.filters<br>
+lcms2mt/Projects/VC2017/transicc/transicc.vcxproj<br>
+lcms2mt/Projects/VC2017/transicc/transicc.vcxproj.filters<br>
+lcms2mt/Projects/cppcheck/lcms2.cppcheck<br>
+lcms2mt/Projects/mac/LittleCMS/._Info.plist<br>
+lcms2mt/Projects/mac/LittleCMS/._LittleCMS.xcodeproj<br>
+lcms2mt/Projects/mac/LittleCMS/English.lproj/InfoPlist.strings<br>
+lcms2mt/Projects/mac/LittleCMS/Info.plist<br>
+lcms2mt/Projects/mac/LittleCMS/LittleCMS.xcodeproj/mariama.mode1v3<br>
+lcms2mt/Projects/mac/LittleCMS/LittleCMS.xcodeproj/mariama.pbxuser<br>
+lcms2mt/Projects/mac/LittleCMS/LittleCMS.xcodeproj/project.pbxproj<br>
+lcms2mt/Projects/mac/LittleCMS/LittleCMS.xcodeproj/project.xcworkspace/contents.xcworkspacedata<br>
+lcms2mt/Projects/mac/LittleCMS/LittleCMS.xcodeproj/project.xcworkspace/xcuserdata/User.xcuserdatad/UserInterfaceState.xcuserstate<br>
+lcms2mt/Projects/mac/LittleCMS/LittleCMS.xcodeproj/project.xcworkspace/xcuserdata/User.xcuserdatad/WorkspaceSettings.xcsettings<br>
+lcms2mt/Projects/mac/LittleCMS/LittleCMS.xcodeproj/xcuserdata/User.xcuserdatad/xcdebugger/Breakpoints.xcbkptlist<br>
+lcms2mt/Projects/mac/LittleCMS/LittleCMS.xcodeproj/xcuserdata/User.xcuserdatad/xcschemes/LittleCMS.xcscheme<br>
+lcms2mt/Projects/mac/LittleCMS/LittleCMS.xcodeproj/xcuserdata/User.xcuserdatad/xcschemes/testbed.xcscheme<br>
+lcms2mt/Projects/mac/LittleCMS/LittleCMS.xcodeproj/xcuserdata/User.xcuserdatad/xcschemes/xcschememanagement.plist<br>
+lcms2mt/Projects/mac/LittleCMS/LittleCMS_Prefix.pch<br>
+lcms2mt/Projects/mac/LittleCMS/TestBed-Info.plist<br>
+lcms2mt/README.1ST<br>
+lcms2mt/aclocal.m4<br>
+lcms2mt/autogen.sh<br>
+lcms2mt/compile<br>
+lcms2mt/config.guess<br>
+lcms2mt/config.sub<br>
+lcms2mt/configure<br>
+lcms2mt/configure.ac<br>
+lcms2mt/depcomp<br>
+lcms2mt/doc/LittleCMS2.9 API.pdf<br>
+lcms2mt/doc/LittleCMS2.9 Plugin API.pdf<br>
+lcms2mt/doc/LittleCMS2.9 tutorial.pdf<br>
+lcms2mt/doc/WhyThisFork.txt<br>
+lcms2mt/doc/src.zip<br>
+lcms2mt/include/Makefile.am<br>
+lcms2mt/include/Makefile.in<br>
+lcms2mt/include/lcms2mt.h<br>
+lcms2mt/include/lcms2mt_plugin.h<br>
+lcms2mt/install-sh<br>
+lcms2mt/lcms2mt.pc.in<br>
+lcms2mt/ltmain.sh<br>
+lcms2mt/m4/acx_pthread.m4<br>
+lcms2mt/m4/ax_append_compile_flags.m4<br>
+lcms2mt/m4/ax_append_flag.m4<br>
+lcms2mt/m4/ax_check_compile_flag.m4<br>
+lcms2mt/m4/ax_gcc_func_attribute.m4<br>
+lcms2mt/m4/ax_require_defined.m4<br>
+lcms2mt/m4/libtool.m4<br>
+lcms2mt/m4/ltoptions.m4<br>
+lcms2mt/m4/ltsugar.m4<br>
+lcms2mt/m4/ltversion.m4<br>
+lcms2mt/m4/lt~obsolete.m4<br>
+lcms2mt/missing<br>
+lcms2mt/src/Makefile.am<br>
+lcms2mt/src/Makefile.in<br>
+lcms2mt/src/cmsalpha.c<br>
+lcms2mt/src/cmscam02.c<br>
+lcms2mt/src/cmscgats.c<br>
+lcms2mt/src/cmscnvrt.c<br>
+lcms2mt/src/cmserr.c<br>
+lcms2mt/src/cmsgamma.c<br>
+lcms2mt/src/cmsgmt.c<br>
+lcms2mt/src/cmshalf.c<br>
+lcms2mt/src/cmsintrp.c<br>
+lcms2mt/src/cmsio0.c<br>
+lcms2mt/src/cmsio1.c<br>
+lcms2mt/src/cmslut.c<br>
+lcms2mt/src/cmsmd5.c<br>
+lcms2mt/src/cmsmtrx.c<br>
+lcms2mt/src/cmsnamed.c<br>
+lcms2mt/src/cmsopt.c<br>
+lcms2mt/src/cmspack.c<br>
+lcms2mt/src/cmspcs.c<br>
+lcms2mt/src/cmsplugin.c<br>
+lcms2mt/src/cmsps2.c<br>
+lcms2mt/src/cmssamp.c<br>
+lcms2mt/src/cmssm.c<br>
+lcms2mt/src/cmstypes.c<br>
+lcms2mt/src/cmsvirt.c<br>
+lcms2mt/src/cmswtpnt.c<br>
+lcms2mt/src/cmsxform.c<br>
+lcms2mt/src/extra_xform.h<br>
+lcms2mt/src/lcms2_internal.h<br>
+lcms2mt/src/lcms2mt.def<br>
+lcms2mt/testbed/Makefile.am<br>
+lcms2mt/testbed/Makefile.in<br>
+lcms2mt/testbed/bad.icc<br>
+lcms2mt/testbed/bad_mpe.icc<br>
+lcms2mt/testbed/crayons.icc<br>
+lcms2mt/testbed/ibm-t61.icc<br>
+lcms2mt/testbed/new.icc<br>
+lcms2mt/testbed/test1.icc<br>
+lcms2mt/testbed/test2.icc<br>
+lcms2mt/testbed/test3.icc<br>
+lcms2mt/testbed/test4.icc<br>
+lcms2mt/testbed/test5.icc<br>
+lcms2mt/testbed/testcms2.c<br>
+lcms2mt/testbed/testcms2.h<br>
+lcms2mt/testbed/testplugin.c<br>
+lcms2mt/testbed/testthread.cpp<br>
+lcms2mt/testbed/toosmall.icc<br>
+lcms2mt/testbed/zoo_icc.c<br>
+lcms2mt/utils/common/utils.h<br>
+lcms2mt/utils/common/vprf.c<br>
+lcms2mt/utils/common/xgetopt.c<br>
+lcms2mt/utils/delphi/delphidemo.dpr<br>
+lcms2mt/utils/delphi/delphidemo.dproj<br>
+lcms2mt/utils/delphi/delphidemo.res<br>
+lcms2mt/utils/delphi/demo1.dfm<br>
+lcms2mt/utils/delphi/demo1.pas<br>
+lcms2mt/utils/delphi/lcms2dll.pas<br>
+lcms2mt/utils/jpgicc/LICENSE_iccjpeg<br>
+lcms2mt/utils/jpgicc/Makefile.am<br>
+lcms2mt/utils/jpgicc/Makefile.in<br>
+lcms2mt/utils/jpgicc/iccjpeg.c<br>
+lcms2mt/utils/jpgicc/iccjpeg.h<br>
+lcms2mt/utils/jpgicc/jpgicc.1<br>
+lcms2mt/utils/jpgicc/jpgicc.c<br>
+lcms2mt/utils/linkicc/Makefile.am<br>
+lcms2mt/utils/linkicc/Makefile.in<br>
+lcms2mt/utils/linkicc/linkicc.1<br>
+lcms2mt/utils/linkicc/linkicc.c<br>
+lcms2mt/utils/matlab/icctrans.c<br>
+lcms2mt/utils/matlab/lcms_rsp<br>
+lcms2mt/utils/psicc/Makefile.am<br>
+lcms2mt/utils/psicc/Makefile.in<br>
+lcms2mt/utils/psicc/psicc.1<br>
+lcms2mt/utils/psicc/psicc.c<br>
+lcms2mt/utils/samples/Makefile.am<br>
+lcms2mt/utils/samples/Makefile.in<br>
+lcms2mt/utils/samples/itufax.c<br>
+lcms2mt/utils/samples/mkcmy.c<br>
+lcms2mt/utils/samples/mkgrayer.c<br>
+lcms2mt/utils/samples/mktiff8.c<br>
+lcms2mt/utils/samples/roundtrip.c<br>
+lcms2mt/utils/samples/vericc.c<br>
+lcms2mt/utils/samples/wtpt.1<br>
+lcms2mt/utils/samples/wtpt.c<br>
+lcms2mt/utils/tificc/Makefile.am<br>
+lcms2mt/utils/tificc/Makefile.in<br>
+lcms2mt/utils/tificc/tifdiff.c<br>
+lcms2mt/utils/tificc/tificc.1<br>
+lcms2mt/utils/tificc/tificc.c<br>
+lcms2mt/utils/transicc/Makefile.am<br>
+lcms2mt/utils/transicc/Makefile.in<br>
+lcms2mt/utils/transicc/transicc.1<br>
+lcms2mt/utils/transicc/transicc.c<br>
+psi/msvc.mak<br>
+psi/os2.mak<br>
+windows/ghostscript.vcproj<br>
+windows/ghostscript_rt.vcxproj<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-02-16 13:51:04 -0800
+</strong>
+<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9ff6b34e461fcbd4ef27fbb6c5c8a15071fe1370">9ff6b34e461fcbd4ef27fbb6c5c8a15071fe1370</a>
+<blockquote>
+<p>
+ Make ICC profile management thread safe.<br>
+<br>
+ The change to ref_count of profiles needs to be protected by a lock if<br>
+ the profile ref_count could be changed by another thread. Also when<br>
+ decrementing the ref_count to 0, we cannot free the lock until after<br>
+ the profile has been unlocked.<br>
+<br>
+ New routine gsicc_adjust_profile_rc replaces old (not threadsafe) function<br>
+ gsicc_profile_reference.<br>
+<br>
+ Also add tracing &quot;cname&quot; to the RC_ADJUST_ macro to aid in debugging<br>
+ with -Z^ debug flag.<br>
+<br>
+ Testing had revealed race conditions which are now fixed (eliminate use<br>
+ of semaphores).<br>
+<br>
+ This also changes the gsicc_lcms2art.c interface functions to keep a<br>
+ list of transforms configured to have differing buffer formats that<br>
+ include alpha, planar IN/OUT, big_endian IN/OUT, bytes_per_component<br>
+ IN/OUT which are cloned as needed by threads.<br>
+<br>
+ Change gscms_is_threadsafe to return &quot;true&quot; in gsicc_lcms2art.c<br>
+<br>
+ TBD: If a link fails to build a thread may hang waiting for the link<br>
+ profile to become valid if it was not the thread that was building it.<br>
+ Not a new condition, but exposed when gscms_is_threadsafe returns true.<br>
+<br>
+ TBD: Fix error handling / clean-up when links fail to build. Also not<br>
+ new, but is needed to prevent leaks, and possibly hang conditions.<br>
+<br>
+base/gdevp14.c<br>
+base/gscdevn.c<br>
+base/gscie.c<br>
+base/gscms.h<br>
+base/gscscie.c<br>
+base/gscspace.c<br>
+base/gsicc.c<br>
+base/gsicc_cache.c<br>
+base/gsicc_lcms2art.c<br>
+base/gsicc_manage.c<br>
+base/gsicc_manage.h<br>
+base/gsicc_monitorcm.c<br>
+base/gsicc_nocm.c<br>
+base/gsicc_replacecm.c<br>
+base/gsmemory.c<br>
+base/gsrefct.h<br>
+base/gstrans.c<br>
+base/gxclist.c<br>
+base/gxclrast.c<br>
+base/gxcmap.c<br>
+base/gxipixel.c<br>
+base/lib.mak<br>
+lcms2art/include/lcms2art.h<br>
+lcms2art/src/cmsxform.c<br>
+lcms2art/src/lcms2art.def<br>
+xps/xpscolor.c<br>
+xps/xpsimage.c<br>
+xps/xpstile.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-03-28 15:24:32 +0100
+</strong>
+<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=33701ac07115cb2f634a40ab73a5c127ca870ad8">33701ac07115cb2f634a40ab73a5c127ca870ad8</a>
+<blockquote>
+<p>
+ Correctly set the 'encoding' to none when we apply UTF-8<br>
+<br>
+ Bug 699156 &quot; Cyrillic file names&quot;<br>
+<br>
+ On Windows GhostXPS, GhostPCL and the windowed executable (gswinxx.exe)<br>
+ were not setting the 'encoding' or were setting it to an incorrect<br>
+ 'local' encoding.<br>
+<br>
+ This led to us incorrectly decoding UTF-8 encoded arguments, in<br>
+ particular the input filename, which caused ioerrors to result.<br>
+<br>
+pcl/pl/plmain.c<br>
+psi/dwmain.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-03-26 20:55:39 +0100
+</strong>
+<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b24a4bd9bab156443c4667d4266e3deb43f933f7">b24a4bd9bab156443c4667d4266e3deb43f933f7</a>
+<blockquote>
+<p>
+ Bug 699141(redux): use &quot;restrict&quot; on compatible compilers<br>
+<br>
+ The definition of gs_restrict was missing for C99 compilers.<br>
+<br>
+ Even with compilers that claim C99 compatibility, we honor the configure check<br>
+ for restrict.<br>
+<br>
+base/stdpre.h<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-03-26 14:56:37 +0100
+</strong>
+<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=12d2e6e44c4ed919bd38f2a13314f4942decd610">12d2e6e44c4ed919bd38f2a13314f4942decd610</a>
+<blockquote>
+<p>
+ Bug 699154: Fix conditional parenthesis in gstype42.c<br>
+<br>
+base/gstype42.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-03-26 14:35:09 +0100
+</strong>
+<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8ec5c5ded5fc19cabd95dad385b22a506e59acaf">8ec5c5ded5fc19cabd95dad385b22a506e59acaf</a>
+<blockquote>
+<p>
+ zfapi.c: another case of is_glyph_index set wrongly<br>
+<br>
+ This is related to freetype now a) automatically selecting a Unicode cmap for<br>
+ every font, if one is available, and b) automatically generating a Unicode cmap<br>
+ for every font when one is not available.<br>
+<br>
+ Logic that we had pushed down to the FAPI/FT interface layer, we now need to<br>
+ apply earlier.<br>
+<br>
+psi/zfapi.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-03-26 09:21:53 +0100
+</strong>
+<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6e4ac5e7f1e8ea1835a99f12a7a4e34ebd85261e">6e4ac5e7f1e8ea1835a99f12a7a4e34ebd85261e</a>
+<blockquote>
+<p>
+ Bug 699141: add configure test for __restrict in compiler<br>
+<br>
+ It seems that some older compilers that claim to support __restrict really don't<br>
+ and compilation fails, so check for that in configure.<br>
+<br>
+base/stdpre.h<br>
+configure.ac<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-03-16 14:49:28 +0000
+</strong>
+<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=145c288cc0b1038b14334b92d40b37d27fd732b5">145c288cc0b1038b14334b92d40b37d27fd732b5</a>
+<blockquote>
+<p>
+ Disable or fix some (benign) compiler warnings for libtiff<br>
+<br>
+base/gsjconf.h<br>
+configure.ac<br>
+psi/msvc.mak<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-03-20 14:58:01 +0000
+</strong>
+<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e3ef00ae7bd46ac4c45bf67cbb03a2342e850dca">e3ef00ae7bd46ac4c45bf67cbb03a2342e850dca</a>
+<blockquote>
+<p>
+ Fix PACIFY_VALGRIND build<br>
+<br>
+ VALGRIND_HG_DISABLE_CHECKING() doesn't exist in all valgrind versions.<br>
+<br>
+pcl/pl/plmain.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-03-16 14:50:22 +0000
+</strong>
+<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fde9abbaf12c0a861dd47792e02752d6b9e6b011">fde9abbaf12c0a861dd47792e02752d6b9e6b011</a>
+<blockquote>
+<p>
+ Fix a couple of unitialized variable warnings<br>
+<br>
+base/gdevdrop.c<br>
+psi/zfont2.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-03-16 14:16:38 +0000
+</strong>
+<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=99deae37f3cf32feac6eefabf17bf34a436c82ab">99deae37f3cf32feac6eefabf17bf34a436c82ab</a>
+<blockquote>
+<p>
+ Fix a &quot;defined but not used&quot; warning<br>
+<br>
+pcl/pcl/rtraster.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-03-16 14:12:16 +0000
+</strong>
+<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=781c6a90b501a7cfcf1cdd337344444e6b388ef6">781c6a90b501a7cfcf1cdd337344444e6b388ef6</a>
+<blockquote>
+<p>
+ Address some compiler warnings adding casts<br>
+<br>
+devices/gdevxalt.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-03-16 14:11:42 +0000
+</strong>
+<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9a3176cae5c0cd4fea05d2369289ec41d44cf842">9a3176cae5c0cd4fea05d2369289ec41d44cf842</a>
+<blockquote>
+<p>
+ Fix a couple of unused variable warnings<br>
+<br>
+devices/gdevdsp.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-03-16 14:11:04 +0000
+</strong>
+<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=465b77b4b9187e99aabad1e436d5c588fa565f97">465b77b4b9187e99aabad1e436d5c588fa565f97</a>
+<blockquote>
+<p>
+ Squash some unitialized variable warnings<br>
+<br>
+contrib/lips4/gdevl4v.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-03-16 10:19:43 +0000
+</strong>
+<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=eb770edd1c4dd9bf6c561f15564e4b8e10cc54b9">eb770edd1c4dd9bf6c561f15564e4b8e10cc54b9</a>
+<blockquote>
+<p>
+ Squash compiler warning in ijs code.<br>
+<br>
+ijs/ijs_exec_unix.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-03-16 10:16:49 +0000
+</strong>
+<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=54e6bb1a12448aca3c48cd062946f564d3a9a4d1">54e6bb1a12448aca3c48cd062946f564d3a9a4d1</a>
+<blockquote>
+<p>
+ Address some compiler warnings in openjpeg<br>
+<br>
+configure.ac<br>
+openjpeg/src/lib/openjp2/j2k.c<br>
+psi/msvc.mak<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-03-16 09:57:02 +0000
+</strong>
+<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d411d72de4d41e0ad436c50d89088dc13e3b3f42">d411d72de4d41e0ad436c50d89088dc13e3b3f42</a>
+<blockquote>
+<p>
+ Shared library compiler warnings: lcms2, openjpeg<br>
+<br>
+ When linking against the system lcms2 and openjpeg there were compiler<br>
+ warnings (we don't see building &quot;normally&quot;).<br>
+<br>
+base/gsicc_lcms2.c<br>
+base/sjpx_openjpeg.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-03-16 09:06:33 +0000
+</strong>
+<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ee08b05dd809984df8c686231b8c8f215f5815f9">ee08b05dd809984df8c686231b8c8f215f5815f9</a>
+<blockquote>
+<p>
+ Squash compiler warning in debug code<br>
+<br>
+base/siscale.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-03-16 09:03:55 +0000
+</strong>
+<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=601e3663d23ddb49af248d539d9c90d9fcec8163">601e3663d23ddb49af248d539d9c90d9fcec8163</a>
+<blockquote>
+<p>
+ For now, conditionally compile out unused structures<br>
+<br>
+ Solves compiler warnings.<br>
+<br>
+base/gdevp14.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-03-26 15:16:19 +0100
+</strong>
+<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f13d74f60441f7f35691fd4de90476057b8535a4">f13d74f60441f7f35691fd4de90476057b8535a4</a>
+<blockquote>
+<p>
+ Bug #699153 - fix cppcheck warning<br>
+<br>
+ Also fix two tab whitespaces, convert to spaces.<br>
+<br>
+base/gsdevice.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-03-26 02:10:10 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=41d6119463a5f013ecbe5d55d2eb707a47fdd294">41d6119463a5f013ecbe5d55d2eb707a47fdd294</a>
+<blockquote>
+<p>
+ Fix 699142: Adaptive pixels can not be pixel to be predicted.<br>
+<br>
+ The fix for 699127 didn't account for the adaptive pixel location<br>
+ being that of the pixel to be predicted. This is of course invalid,<br>
+ and this is now recitified.<br>
+<br>
+jbig2dec/jbig2_generic.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-03-26 09:59:27 +0100
+</strong>
+<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=af2cf274d086e9140b388b7b1d92ab7753108491">af2cf274d086e9140b388b7b1d92ab7753108491</a>
+<blockquote>
+<p>
+ Coverity ID 26634 - add some return code checks<br>
+<br>
+base/gsstate.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-03-23 08:45:39 +0000
+</strong>
+<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1a3fdb0a05b50a5ddff2d5d566979708ff350ffa">1a3fdb0a05b50a5ddff2d5d566979708ff350ffa</a>
+<blockquote>
+<p>
+ Add another missing file to the documentation install list<br>
+<br>
+ I'd missed off the example device source file.<br>
+<br>
+base/unixinst.mak<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-03-07 09:59:55 +0000
+</strong>
+<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=59b5259ffa6155c3c9341a268310e3879e96d441">59b5259ffa6155c3c9341a268310e3879e96d441</a>
+<blockquote>
+<p>
+ Bring master up to date with 9.23 release branch<br>
+<br>
+ (gs923)<br>
+<br>
+base/version.mak<br>
+doc/API.htm<br>
+doc/C-style.htm<br>
+doc/Commprod.htm<br>
+doc/DLL.htm<br>
+doc/Deprecated.htm<br>
+doc/Details8.htm<br>
+doc/Details9.htm<br>
+doc/Develop.htm<br>
+doc/Devices.htm<br>
+doc/Drivers.htm<br>
+doc/Fonts.htm<br>
+doc/Helpers.htm<br>
+doc/History1.htm<br>
+doc/History2.htm<br>
+doc/History3.htm<br>
+doc/History4.htm<br>
+doc/History5.htm<br>
+doc/History6.htm<br>
+doc/History7.htm<br>
+doc/History8.htm<br>
+doc/History9.htm<br>
+doc/Install.htm<br>
+doc/Issues.htm<br>
+doc/Language.htm<br>
+doc/Lib.htm<br>
+doc/Make.htm<br>
+doc/News.htm<br>
+doc/Projects.htm<br>
+doc/Ps-style.htm<br>
+doc/Ps2epsi.htm<br>
+doc/Psfiles.htm<br>
+doc/Readme.htm<br>
+doc/Release.htm<br>
+doc/SavedPages.htm<br>
+doc/Source.htm<br>
+doc/Unix-lpr.htm<br>
+doc/Use.htm<br>
+doc/VectorDevices.htm<br>
+doc/WhatIsGS.htm<br>
+doc/gs-vms.hlp<br>
+doc/sample_downscale_device.htm<br>
+doc/thirdparty.htm<br>
+man/dvipdf.1<br>
+man/gs.1<br>
+man/gslp.1<br>
+man/gsnd.1<br>
+man/pdf2dsc.1<br>
+man/pdf2ps.1<br>
+man/pf2afm.1<br>
+man/pfbtopfa.1<br>
+man/printafm.1<br>
+man/ps2ascii.1<br>
+man/ps2epsi.1<br>
+man/ps2pdf.1<br>
+man/ps2pdfwr.1<br>
+man/ps2ps.1<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-03-22 11:30:03 +0000
+</strong>
+<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=57d33404ce0fab68a909fff501c0b8e2912b9956">57d33404ce0fab68a909fff501c0b8e2912b9956</a>
+<blockquote>
+<p>
+ Check __STDC_VERSION__ is defined before using it<br>
+<br>
+ Not all compilers (and versions) have __STDC_VERSION__<br>
+<br>
+base/stdpre.h<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-03-22 11:16:09 +0000
+</strong>
+<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=829c4c55f8b0d77ead0c3daf3ab4164c6b7d8365">829c4c55f8b0d77ead0c3daf3ab4164c6b7d8365</a>
+<blockquote>
+<p>
+ Fix FAPI's CharString dictionary accessing<br>
+<br>
+ Because dictionaries are (generally) made up of sparse arrays (one each for<br>
+ keys and values), it's not generally safe to simply access indices into those<br>
+ arrays - which the FAPI code was doing.<br>
+<br>
+ Normally, for that type of access, we'd use the dictionary content enumerator<br>
+ function but, in this case, the FAPI API does not enforce iterating through<br>
+ the dictionary contents, but allows for &quot;random&quot; accessing the contents.<br>
+<br>
+ However, the requirement to handle broken or invalid CharStrings also means we<br>
+ neatly handle empty slots in the sparse arrays.<br>
+<br>
+ So, the only change required here is to use the maximum size of the dictionary<br>
+ object, rather than the &quot;size&quot; to know how many indices to check.<br>
+<br>
+ As an additional safety check, however, also add checks for the key/value<br>
+ types, and treat an invalid type as an empty slot.<br>
+<br>
+psi/zfapi.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-03-22 11:21:13 +0000
+</strong>
+<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8ac0975771838c7d8c17f5f2f7223607eb976788">8ac0975771838c7d8c17f5f2f7223607eb976788</a>
+<blockquote>
+<p>
+ PS interpreter - fix parsing of NChannel Colorants dictionary<br>
+<br>
+ The code was previously using dict_index_entry to retrieve entries<br>
+ from the Colorants dictionary, but it did not account for the function<br>
+ returning gs_error_undefined when a slot in the dictionary was present<br>
+ but unused. Since dictionaries are sparse arrays, this is possible.<br>
+<br>
+ This commit reworks the code to use dict_first() and dict_next() to<br>
+ retrieve elements from the dictionary, and starts at the maximum entry<br>
+ and works down, instead of the previous code which started at 0 and<br>
+ worked up.<br>
+<br>
+psi/zcolor.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-03-20 21:42:39 +0000
+</strong>
+<br>Shailesh Mistry &lt;shailesh.mistry@hotmail.co.uk&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e54754db42c2640c10a73b18779213d16dbd10d0">e54754db42c2640c10a73b18779213d16dbd10d0</a>
+<blockquote>
+<p>
+ Bug 697545 : Update functions to return error codes.<br>
+<br>
+ Prevent numerous SEGV points by ensuring error codes are returned and<br>
+ handled appropriately<br>
+<br>
+base/gsptype1.c<br>
+base/gximage1.c<br>
+base/gxipixel.c<br>
+base/gxpcmap.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-03-21 02:43:52 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=94d46eea5dada844ac4d9767dfb7a384a408e111">94d46eea5dada844ac4d9767dfb7a384a408e111</a>
+<blockquote>
+<p>
+ Fix 698839: Remove testcase that cannot be found from testrunner.<br>
+<br>
+jbig2dec/test_jbig2dec.py<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-03-21 02:38:15 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=222403964eb437c0b60404fcc11bb879744d263e">222403964eb437c0b60404fcc11bb879744d263e</a>
+<blockquote>
+<p>
+ Fix 698839: Add hash for testcases that fail to decode anything.<br>
+<br>
+ The testrunner stated that the expected hash for 042_13.jb2 and<br>
+ 042_14.jb2 was that of a successfully decoded image. Historically<br>
+ these two images have caused jbig2dec to segfault, but nowadays<br>
+ they correctly cause FATAL ERRORs. When FATAL ERRORs are<br>
+ encountered as hash covering 0 bytes of image data is computed,<br>
+ so the testrunner now expects this hash instead. Therefore the<br>
+ check now run successfully.<br>
+<br>
+jbig2dec/test_jbig2dec.py<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-03-21 02:30:12 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=430fcce8516a3c38f03e8f81d4d8b3e87a5aff28">430fcce8516a3c38f03e8f81d4d8b3e87a5aff28</a>
+<blockquote>
+<p>
+ Fix 698839: Have the testsuite runner return the result.<br>
+<br>
+ Previously the return value was None regardless of test succeeded<br>
+ or failed. This meant that the test_jbig2dec.py script had an<br>
+ exit code of 1 not matter the outcome. Now it is 0 upon success<br>
+ and 1 upon error, as expected by the make check infrastructure.<br>
+<br>
+jbig2dec/test_jbig2dec.py<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-03-21 00:44:00 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3431972e91c51403cf4223f1d5c28b666ea84c6e">3431972e91c51403cf4223f1d5c28b666ea84c6e</a>
+<blockquote>
+<p>
+ Fix 698839: Set correct checksum for amb_{1,2}.jb2 in test suite.<br>
+<br>
+jbig2dec/test_jbig2dec.py<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-03-20 13:16:40 +0000
+</strong>
+<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d8d4a64468252f5b632891fa9c8fdf98930fae15">d8d4a64468252f5b632891fa9c8fdf98930fae15</a>
+<blockquote>
+<p>
+ Add missing files to doc install target<br>
+<br>
+ These files:<br>
+<br>
+ VectorDevices.htm<br>
+ sample_downscale_device.htm<br>
+ SavedPages.htm<br>
+ subclass.htm<br>
+<br>
+ were missing from the documentation installation target<br>
+<br>
+base/unixinst.mak<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-03-20 14:13:00 +0000
+</strong>
+<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=18ec3899047e26109548cb601f0bf830a86d9abe">18ec3899047e26109548cb601f0bf830a86d9abe</a>
+<blockquote>
+<p>
+ Coverty ID 94548 - check return value<br>
+<br>
+psi/zupath.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-03-20 13:36:31 +0000
+</strong>
+<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a9f78155bc0f5050359ea6dfbfb5166e4f72a9cf">a9f78155bc0f5050359ea6dfbfb5166e4f72a9cf</a>
+<blockquote>
+<p>
+ Coverity ID 26487 - remove duplicate branch<br>
+<br>
+devices/gdevpdfimg.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-03-20 12:10:15 +0000
+</strong>
+<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=46b6212e1688ba5d49923908d3be3f9329dd705b">46b6212e1688ba5d49923908d3be3f9329dd705b</a>
+<blockquote>
+<p>
+ PDF interpreter - remove /.gs.pdfobj# entries from pdfmarks<br>
+<br>
+ Since we increased the places where we use /.gs.pfgobj# to track the<br>
+ PDF object number, we have been emitting PDF files from pdfwrite<br>
+ which contain dictionaries with illegal PDF names.<br>
+<br>
+ The '#' in PDF naming is used to escape unprintable characters (eg<br>
+ space), it must be followed by 2 hex digits, ours isn't.<br>
+<br>
+ Trying to fix this in the pdfmark processing proved problematic, so<br>
+ instead, remove it at the PostScritp level.<br>
+<br>
+Resource/Init/pdf_draw.ps<br>
+Resource/Init/pdf_main.ps<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-03-20 02:28:20 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8cf6ddf78db5fc4a453df1a1a9d3ea120ba47609">8cf6ddf78db5fc4a453df1a1a9d3ea120ba47609</a>
+<blockquote>
+<p>
+ Fix 698840: Fix typo in exit code in command-line tool.<br>
+<br>
+ This was introduced in 301726dd5c9c60c1e54eb0965c1d45b36350ce2e.<br>
+<br>
+ Thanks to Max Rees for reporting.<br>
+<br>
+jbig2dec/jbig2dec.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-03-18 14:09:16 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=71bf7cb0c4aa3d2bb06deac2df675af44b3e4c3b">71bf7cb0c4aa3d2bb06deac2df675af44b3e4c3b</a>
+<blockquote>
+<p>
+ Fix 699127: JBIG2 adaptive pixels restricted to field.<br>
+<br>
+ When decoding generic regions the adaptive pixels must be<br>
+ restricted to a field, previously this was not validated,<br>
+ leading to out of buffer accesses.<br>
+<br>
+ This is now validated and may generate a fatal error.<br>
+<br>
+jbig2dec/jbig2_generic.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-03-19 13:47:36 +0000
+</strong>
+<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=bb2ea8ca0482cb0bb5632c30e9184e3d19fdc8d2">bb2ea8ca0482cb0bb5632c30e9184e3d19fdc8d2</a>
+<blockquote>
+<p>
+ pdfwrite - ensure correct ICC profile version being written out<br>
+<br>
+ Bug #699104 &quot;Identify ICC profiles unsuitable for embedding in output PDF and fall back to device space&quot;<br>
+<br>
+ Previously we did not check the minor version number of ICC profiles<br>
+ when writing an ICCBased colour space. Since PDF versions below 1.7<br>
+ support either 4.0.0 0r 4.1.0, this could mean that we wrote a version<br>
+ of profile that was too great for teh PDF version.<br>
+<br>
+ Following on from Michael's commit f732ea3a999f73afa46c2cc4ca28b067f671d29c<br>
+ we can now determine the minor version number of profiles, and we now<br>
+ use that to decide whether to use the profile as it is, or drop back to<br>
+ a version 2 profile.<br>
+<br>
+ Since falling back to a version 2 profile can cause subtle changes in<br>
+ colour, we now make the default CompatibilityLevel for PDF output 1.7.<br>
+ Some PDFSETTINGS convert all colours to device spaces and these have<br>
+ not been altered (not required). We could have defaulted to PDF 2.0<br>
+ output, but the code is rather new, and also prevents certain constructs<br>
+ (eg TransferFunction in the graphics state).<br>
+<br>
+Resource/Init/gs_pdfwr.ps<br>
+devices/vector/gdevpdf.c<br>
+devices/vector/gdevpdfk.c<br>
+doc/VectorDevices.htm<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-03-19 11:13:13 +0000
+</strong>
+<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5fe0dbb5de65ca92a0ba8ff4a96447e30e4366e8">5fe0dbb5de65ca92a0ba8ff4a96447e30e4366e8</a>
+<blockquote>
+<p>
+ pdfwrite - remove special case for GS_UNDEFINED ICC profile colour space<br>
+<br>
+ Since commit f732ea3a999f73afa46c2cc4ca28b067f671d29c the cs_data<br>
+ member of ICC profiles generated internally is correctly set. So we no<br>
+ longer need to special-case ICC profiles where the cs_data member is<br>
+ GS_UNDEFINED.<br>
+<br>
+devices/vector/gdevpdfk.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-03-19 10:29:38 +0000
+</strong>
+<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8078194fd8abe7c9c3088573b9e69a4a967b6ee0">8078194fd8abe7c9c3088573b9e69a4a967b6ee0</a>
+<blockquote>
+<p>
+ Bug 699122 - valgrind regression<br>
+<br>
+ Somewhat to my surprise, calling gs_setcolorspace does not set the<br>
+ device colour, and leaves 'ccolor_valid' in an undefined state.<br>
+<br>
+ Call gs_set_dev_color() to explicitly set the device colour after we<br>
+ reset the device space to gray in gs_initgraphics()<br>
+<br>
+base/gsstate.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-03-16 13:27:45 +0000
+</strong>
+<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9b9acd5a8e074bbb47107f6add7b8afb1fe43270">9b9acd5a8e074bbb47107f6add7b8afb1fe43270</a>
+<blockquote>
+<p>
+ Fix ommission from revised documentation install path<br>
+<br>
+base/unixinst.mak<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-03-18 12:33:22 -0700
+</strong>
+<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f732ea3a999f73afa46c2cc4ca28b067f671d29c">f732ea3a999f73afa46c2cc4ca28b067f671d29c</a>
+<blockquote>
+<p>
+ Bug 699104 make sure data_cs is populated when creating profiles<br>
+<br>
+ Also, added a method to return the major and minor version numbers<br>
+ for use in pdf write.<br>
+<br>
+base/gsciemap.c<br>
+base/gsicc_manage.c<br>
+base/gsicc_manage.h<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-03-15 19:14:15 +0000
+</strong>
+<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=269663402c5210dd1a15131a045526e3cd6de479">269663402c5210dd1a15131a045526e3cd6de479</a>
+<blockquote>
+<p>
+ pdfimage devices - fix up some minor problems<br>
+<br>
+ Bug #699119 &quot; pdfimage24 creates bad PDF&quot;<br>
+<br>
+ When I removed some extraneous stuff from the output (to simplify it) I<br>
+ forgot to update the pdfimage devices properly, leading to them trying<br>
+ to write xref entries for missing data.<br>
+<br>
+ In addition, there was a problem writing the Length object of the image<br>
+ streams.<br>
+<br>
+ Ghostscript complained about both of these but rendered the content<br>
+ correctly, other consumers didn't complain.<br>
+<br>
+devices/gdevpdfimg.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-03-15 11:04:40 +0000
+</strong>
+<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=124b37fc65fe665d8b4a6133142784c4edb3b3bf">124b37fc65fe665d8b4a6133142784c4edb3b3bf</a>
+<blockquote>
+<p>
+ lcms2art: byteReverse needs a ContextID<br>
+<br>
+ on big endian platforms - fix that.<br>
+<br>
+ Reported against 9.23 RC1<br>
+<br>
+lcms2art/src/cmsmd5.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-01-29 15:32:52 +0000
+</strong>
+<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e0f461a8a634036bbff938492190c72fcef684ac">e0f461a8a634036bbff938492190c72fcef684ac</a>
+<blockquote>
+<p>
+ Tweak indent of comment.<br>
+<br>
+base/gsicc_lcms2art.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-03-14 19:49:29 +0000
+</strong>
+<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=40263f15745f9cf9477acc35708bf61a2de46a6b">40263f15745f9cf9477acc35708bf61a2de46a6b</a>
+<blockquote>
+<p>
+ Simplify image enumerator rectangle logic for scalers.<br>
+<br>
+ We store the image size as a rectangle in the image enumerator.<br>
+ For the purposes of scaling, we also store the rectangle that<br>
+ needs to be rendered. We expand this slightly to allow for<br>
+ the support requirements of the scaler, thus giving a rectangle<br>
+ that is really what we need to decode.<br>
+<br>
+ In order to correctly setup the scaler we then need to try to<br>
+ guess how much expansion was done. My previous attempts at<br>
+ this guesswork failed.<br>
+<br>
+ A simpler solution would appear to be to just save both the<br>
+ render and decode rectangles stored separately. This simplifies<br>
+ the logic.<br>
+<br>
+base/gximage.h<br>
+base/gxipixel.c<br>
+base/gxiscale.c<br>
+base/sisparam.h<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-03-12 18:53:45 +0000
+</strong>
+<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=088cae9953f3a692201915c91bc87260add91fc6">088cae9953f3a692201915c91bc87260add91fc6</a>
+<blockquote>
+<p>
+ lcms2art: Split transforms in two.<br>
+<br>
+ Each cmsTransform now has a 'core' part and a part that can<br>
+ be 'cloned' to change the buffer formats.<br>
+<br>
+ The plan is to drop cmsChangeBuffersFormat and use this instead<br>
+ to make sure we truly are thread safe.<br>
+<br>
+lcms2art/include/lcms2art.h<br>
+lcms2art/src/cmsalpha.c<br>
+lcms2art/src/cmsnamed.c<br>
+lcms2art/src/cmsplugin.c<br>
+lcms2art/src/cmsps2.c<br>
+lcms2art/src/cmsvirt.c<br>
+lcms2art/src/cmsxform.c<br>
+lcms2art/src/extra_xform.h<br>
+lcms2art/src/lcms2_internal.h<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-03-12 18:53:17 +0000
+</strong>
+<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=85569e3bd463ff2b67c195dd84ed770d2f86eb8f">85569e3bd463ff2b67c195dd84ed770d2f86eb8f</a>
+<blockquote>
+<p>
+ Update VS project for lcms2 -&gt; lcms2art change.<br>
+<br>
+windows/ghostscript.vcproj<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-03-14 19:38:01 +0000
+</strong>
+<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ad292af74cbb8e823cf2829d29a35661caf1c49c">ad292af74cbb8e823cf2829d29a35661caf1c49c</a>
+<blockquote>
+<p>
+ Fix typo in Memento_breakpointLocked.<br>
+<br>
+base/memento.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-03-14 16:41:03 +0000
+</strong>
+<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=34e279b84a6271c37a5a51ccefaccd2362845e73">34e279b84a6271c37a5a51ccefaccd2362845e73</a>
+<blockquote>
+<p>
+ Revert &quot;Tweak bitmap interpolater patch size.&quot;<br>
+<br>
+ This reverts commit 38e0c643e62087c089c59c9ad44fc468dd09cd37.<br>
+<br>
+ This was shown to cause problems with:<br>
+<br>
+ tests_private/pdf/PDFIA1.7_SUBSET/IA3Z3225.pdf.pdf.psdcmyk.300.1<br>
+<br>
+ (or tests_private/pdf/PDFIA1.7_SUBSET/IA3Z3225.pdf, page 2, tweaked<br>
+ to rotate by 270).<br>
+<br>
+ Reverting for now so I can try to find a less hacky (and hence<br>
+ less error prone) way of working.<br>
+<br>
+base/gxiscale.c<br>
+base/sisparam.h<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-03-01 15:04:48 +0800
+</strong>
+<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=36ab38b53695ae4b212507c45ec07f117ff26e2d">36ab38b53695ae4b212507c45ec07f117ff26e2d</a>
+<blockquote>
+<p>
+ Fix 699083: Avoid leak in symbol dictionary parsing upon error.<br>
+<br>
+jbig2dec/jbig2_symbol_dict.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-03-13 12:20:33 +0000
+</strong>
+<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=151aa07a734101182b1861c3113c2539d2d8a485">151aa07a734101182b1861c3113c2539d2d8a485</a>
+<blockquote>
+<p>
+ pdfwrite - correct a function name<br>
+<br>
+ stupid typo in function name, its been annoying me for years.<br>
+<br>
+devices/vector/gdevpdtt.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-03-13 10:37:08 +0000
+</strong>
+<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cb018b64dea61f2d6146652dce349d3fadab1709">cb018b64dea61f2d6146652dce349d3fadab1709</a>
+<blockquote>
+<p>
+ Squash a benign compiler warning<br>
+<br>
+devices/vector/gdevpdtt.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-03-13 10:36:45 +0000
+</strong>
+<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9ad220db0c06b9a22bd757f92edaaf624b701b1b">9ad220db0c06b9a22bd757f92edaaf624b701b1b</a>
+<blockquote>
+<p>
+ pdfwrite - don't write device spaces for masks representing glyphs<br>
+<br>
+ This came up while looking into ICC profile embedding. If we are<br>
+ processing a mask bitmap which represents a glyph (eg when creating a<br>
+ type 3 font for a font which cannot be embedded directly in a PDF) we<br>
+ do not want to write a device colour.<br>
+<br>
+ We probably *never* want to write a device colour in here, but I'm not<br>
+ certain of that, I am certain that the high level colour will already<br>
+ have been set if we are processing text though. So in this commit, limit<br>
+ the change so that we don't write device colours for glyphs.<br>
+<br>
+devices/vector/gdevpdfb.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-03-13 10:33:52 +0000
+</strong>
+<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f06d2b00d005012379d4a2f6f47aab99b7b13b5c">f06d2b00d005012379d4a2f6f47aab99b7b13b5c</a>
+<blockquote>
+<p>
+ pdfwrite - reject inappropriate ICC profiles<br>
+<br>
+ PDF files cannot include the full possible range of ICC profiles, if<br>
+ we encounter one of these (eg from an XPS file) then refuse to embed it<br>
+ and instead return gs_error_rangecheck, so that the calling code will<br>
+ fall back to a device space representation.<br>
+<br>
+ NOTE we currently permit GS_UNDEFINED as a valid data_cs which we really<br>
+ shouldn't but the current code, when converting a CIEBasedDEF or<br>
+ CIEBasedDEFG (possibly other CIE spaces) to ICC creates a profile<br>
+ where data_cs is GS_UNDEFINED (which is 0, so probably not actually<br>
+ filled in).<br>
+<br>
+devices/vector/gdevpdfk.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-03-06 12:22:23 +0000
+</strong>
+<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d6bdb65a51e154402a173182e8d1beccba610ea0">d6bdb65a51e154402a173182e8d1beccba610ea0</a>
+<blockquote>
+<p>
+ Memento: Add Mutex to protect Memento operations.<br>
+<br>
+ Solves problems that Ray was seeing while debugging the multithreaded<br>
+ integration of our modified LCMS2.<br>
+<br>
+base/memento.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-03-12 14:22:44 +0000
+</strong>
+<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c6596a021cbe1cd716eaf50e3dd06de646e05572">c6596a021cbe1cd716eaf50e3dd06de646e05572</a>
+<blockquote>
+<p>
+ pdfwrite - avoid use of /.notdef when converting PCL fonts to type 3<br>
+<br>
+ Bug #699102 &quot;using -sDEVICE=pdfwrite option generate an incorrect code 128 barcode&quot;<br>
+<br>
+ This is actually an Acrobat bug, every other viewer I've tested works as<br>
+ expected, Acrobat does not.<br>
+<br>
+ The problem appears to be related to defining a /.notdef glyph and<br>
+ encoding it at a position other than 0 in the Encoding. If we do that,<br>
+ and use the encoded /.notdef glyph, Acrobat quietly replaces it with the<br>
+ glyph encoded at position 0 in the Encoding of the font.<br>
+<br>
+ Because of the way that PCL fonts work, when we are converting PCL<br>
+ fonts to type 3 PDF fonts, the character (PCL) 0x1D gets assigned the<br>
+ glyph name /.notdef. The actual Encoding of the glyph is at position<br>
+ 0x1D however, which causes Acrobat to substitute the glyph at Encoding<br>
+ position 0.<br>
+<br>
+ This is obviously wrong. However, since its Acrobat, here we add yet<br>
+ another heuristic to avoid defining glyphs with the name /.notdef when<br>
+ creating type 3 PDF fonts from PCL fonts.<br>
+<br>
+ No differences expected<br>
+<br>
+devices/vector/gdevpdtt.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-03-07 18:31:23 +0000
+</strong>
+<br>Shailesh Mistry &lt;shailesh.mistry@hotmail.co.uk&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3b3d8f74dc026c4f1af5022a1527d41d21511401">3b3d8f74dc026c4f1af5022a1527d41d21511401</a>
+<blockquote>
+<p>
+ Bug 697545 : Prevent SEGV from gs_make_pattern_common.<br>
+<br>
+ Prevent SEGV if memory allocation fails and returns an empty path.<br>
+<br>
+ Error created using :-<br>
+ MEMENTO_FAILAT=9104 ./membin/gpcl6 -sDEVICE=ppmraw -o /dev/null ./pcl/examples/owl.pcl<br>
+<br>
+base/gspcolor.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-03-08 13:21:54 +0000
+</strong>
+<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d68b62d7567f20f0f269d096b899bd2409967980">d68b62d7567f20f0f269d096b899bd2409967980</a>
+<blockquote>
+<p>
+ Avoid total image dropout in interplated rescales.<br>
+<br>
+ Tests show that the following command causes images to disappear:<br>
+<br>
+ gxps -o out.ppm -sDEVICE=ppmraw -72 tests_private/xps/xpsfts-a4/fts_27xx.xps<br>
+<br>
+ This is because we scale a 1600 wide image down to 27 pixels across.<br>
+ As such the weights for each individual pixel round to zero, and we<br>
+ get nothing displayed.<br>
+<br>
+ Adjust for this by still calculating weights as doubles, and carrying<br>
+ the error across the line. This keeps the total sum of the differences<br>
+ correct.<br>
+<br>
+base/siscale.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-03-06 21:57:06 +0000
+</strong>
+<br>Shailesh Mistry &lt;shailesh.mistry@hotmail.co.uk&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=676dfb338d296aa86630662714fce5f058e31b8f">676dfb338d296aa86630662714fce5f058e31b8f</a>
+<blockquote>
+<p>
+ Bug 697545 : Update functions to return error codes.<br>
+<br>
+ Prevent numerous SEGV points by ensuring error codes are returned and<br>
+ handled appropriately<br>
+<br>
+pcl/pxl/pxsessio.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-03-06 20:33:02 +0000
+</strong>
+<br>Shailesh Mistry &lt;shailesh.mistry@hotmail.co.uk&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2926860ca8ce519dadf23e44a9b4828da70090c4">2926860ca8ce519dadf23e44a9b4828da70090c4</a>
+<blockquote>
+<p>
+ Bug 697545 : Update functions to return error codes.<br>
+<br>
+ Each parameter handling function has been updated to ensure error codes<br>
+ are returned and handled appropriately and gs_c_param_list_release is<br>
+ always called on exit.<br>
+<br>
+pcl/pcl/pcommand.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-03-07 12:16:51 +0000
+</strong>
+<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cfada4acb65861b4361ad80dbb53f61c5dc94c96">cfada4acb65861b4361ad80dbb53f61c5dc94c96</a>
+<blockquote>
+<p>
+ Bump version - prep for release<br>
+<br>
+Resource/Init/gs_init.ps<br>
+base/version.mak<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-03-21 08:44:23 +0000
+</strong>
+<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a03872ea339d60055fa09dc451ebf37442f467fb">a03872ea339d60055fa09dc451ebf37442f467fb</a>
+<blockquote>
+<p>
+ Final changelog for 9.23 release<br>
+<br>
+doc/History9.htm<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-03-21 08:41:35 +0000
+</strong>
+<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=eb210aecab59f338ef9b8af4523edb3c8bc35092">eb210aecab59f338ef9b8af4523edb3c8bc35092</a>
+<blockquote>
+<p>
+ Dates, changelog and product string for release<br>
+<br>
+base/gscdef.c<br>
+base/version.mak<br>
+doc/API.htm<br>
+doc/C-style.htm<br>
+doc/Commprod.htm<br>
+doc/DLL.htm<br>
+doc/Deprecated.htm<br>
+doc/Details8.htm<br>
+doc/Details9.htm<br>
+doc/Develop.htm<br>
+doc/Devices.htm<br>
+doc/Drivers.htm<br>
+doc/Fonts.htm<br>
+doc/Helpers.htm<br>
+doc/History1.htm<br>
+doc/History2.htm<br>
+doc/History3.htm<br>
+doc/History4.htm<br>
+doc/History5.htm<br>
+doc/History6.htm<br>
+doc/History7.htm<br>
+doc/History8.htm<br>
+doc/History9.htm<br>
+doc/Install.htm<br>
+doc/Issues.htm<br>
+doc/Language.htm<br>
+doc/Lib.htm<br>
+doc/Make.htm<br>
+doc/News.htm<br>
+doc/Projects.htm<br>
+doc/Ps-style.htm<br>
+doc/Ps2epsi.htm<br>
+doc/Psfiles.htm<br>
+doc/Readme.htm<br>
+doc/Release.htm<br>
+doc/SavedPages.htm<br>
+doc/Source.htm<br>
+doc/Unix-lpr.htm<br>
+doc/Use.htm<br>
+doc/VectorDevices.htm<br>
+doc/WhatIsGS.htm<br>
+doc/gs-vms.hlp<br>
+doc/sample_downscale_device.htm<br>
+doc/thirdparty.htm<br>
+man/dvipdf.1<br>
+man/gs.1<br>
+man/gslp.1<br>
+man/gsnd.1<br>
+man/pdf2dsc.1<br>
+man/pdf2ps.1<br>
+man/pf2afm.1<br>
+man/pfbtopfa.1<br>
+man/printafm.1<br>
+man/ps2ascii.1<br>
+man/ps2epsi.1<br>
+man/ps2pdf.1<br>
+man/ps2pdfwr.1<br>
+man/ps2ps.1<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-03-20 13:16:40 +0000
+</strong>
+<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=41c92643ce1325893d0f491a49fb2edad1684d17">41c92643ce1325893d0f491a49fb2edad1684d17</a>
+<blockquote>
+<p>
+ Add missing files to doc install target<br>
+<br>
+ These files:<br>
+<br>
+ VectorDevices.htm<br>
+ sample_downscale_device.htm<br>
+ SavedPages.htm<br>
+ subclass.htm<br>
+<br>
+ were missing from the documentation installation target<br>
+<br>
+base/unixinst.mak<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-03-16 13:27:45 +0000
+</strong>
+<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6ca20f5735e9cde19eee6577059cd9d844e94525">6ca20f5735e9cde19eee6577059cd9d844e94525</a>
+<blockquote>
+<p>
+ Fix ommission from revised documentation install path<br>
+<br>
+base/unixinst.mak<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-03-15 19:14:15 +0000
+</strong>
+<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=713d80d0dde40a5d1d1f402e8347997896b9a8f7">713d80d0dde40a5d1d1f402e8347997896b9a8f7</a>
+<blockquote>
+<p>
+ pdfimage devices - fix up some minor problems<br>
+<br>
+ Bug #699119 &quot; pdfimage24 creates bad PDF&quot;<br>
+<br>
+ When I removed some extraneous stuff from the output (to simplify it) I<br>
+ forgot to update the pdfimage devices properly, leading to them trying<br>
+ to write xref entries for missing data.<br>
+<br>
+ In addition, there was a problem writing the Length object of the image<br>
+ streams.<br>
+<br>
+ Ghostscript complained about both of these but rendered the content<br>
+ correctly, other consumers didn't complain.<br>
+<br>
+devices/gdevpdfimg.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-03-15 11:04:40 +0000
+</strong>
+<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7f822afbb52a6b37fc4766f840e714d9f491da81">7f822afbb52a6b37fc4766f840e714d9f491da81</a>
+<blockquote>
+<p>
+ lcms2art: byteReverse needs a ContextID<br>
+<br>
+ on big endian platforms - fix that.<br>
+<br>
+ Reported against 9.23 RC1<br>
+<br>
+lcms2art/src/cmsmd5.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-03-15 07:50:41 +0000
+</strong>
+<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=36bc37e414b695b1fa39c7e99be9d83f8628e889">36bc37e414b695b1fa39c7e99be9d83f8628e889</a>
+<blockquote>
+<p>
+ Changelog and product string for 9.23 rc3<br>
+<br>
+base/gscdef.c<br>
+doc/History9.htm<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-03-14 16:41:03 +0000
+</strong>
+<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e31e3879532fd23ca2658aea26bf4cadd665687f">e31e3879532fd23ca2658aea26bf4cadd665687f</a>
+<blockquote>
+<p>
+ Revert &quot;Tweak bitmap interpolater patch size.&quot;<br>
+<br>
+ This reverts commit 38e0c643e62087c089c59c9ad44fc468dd09cd37.<br>
+<br>
+ This was shown to cause problems with:<br>
+<br>
+ tests_private/pdf/PDFIA1.7_SUBSET/IA3Z3225.pdf.pdf.psdcmyk.300.1<br>
+<br>
+ (or tests_private/pdf/PDFIA1.7_SUBSET/IA3Z3225.pdf, page 2, tweaked<br>
+ to rotate by 270).<br>
+<br>
+ Reverting for now so I can try to find a less hacky (and hence<br>
+ less error prone) way of working.<br>
+<br>
+base/gxiscale.c<br>
+base/sisparam.h<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-03-14 07:47:37 +0000
+</strong>
+<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=56888d7a2e8b9cade1fc9535b67bd9841e2aca6e">56888d7a2e8b9cade1fc9535b67bd9841e2aca6e</a>
+<blockquote>
+<p>
+ Update changelog for 9.23 rc2<br>
+<br>
+doc/History9.htm<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-03-14 07:45:29 +0000
+</strong>
+<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f7acb2502eadeff35dc791b52400d1a301059927">f7acb2502eadeff35dc791b52400d1a301059927</a>
+<blockquote>
+<p>
+ Dates etc for 9.23 rc2<br>
+<br>
+base/version.mak<br>
+doc/API.htm<br>
+doc/C-style.htm<br>
+doc/Commprod.htm<br>
+doc/DLL.htm<br>
+doc/Deprecated.htm<br>
+doc/Details8.htm<br>
+doc/Details9.htm<br>
+doc/Develop.htm<br>
+doc/Devices.htm<br>
+doc/Drivers.htm<br>
+doc/Fonts.htm<br>
+doc/Helpers.htm<br>
+doc/History1.htm<br>
+doc/History2.htm<br>
+doc/History3.htm<br>
+doc/History4.htm<br>
+doc/History5.htm<br>
+doc/History6.htm<br>
+doc/History7.htm<br>
+doc/History8.htm<br>
+doc/History9.htm<br>
+doc/Install.htm<br>
+doc/Issues.htm<br>
+doc/Language.htm<br>
+doc/Lib.htm<br>
+doc/Make.htm<br>
+doc/News.htm<br>
+doc/Projects.htm<br>
+doc/Ps-style.htm<br>
+doc/Ps2epsi.htm<br>
+doc/Psfiles.htm<br>
+doc/Readme.htm<br>
+doc/Release.htm<br>
+doc/SavedPages.htm<br>
+doc/Source.htm<br>
+doc/Unix-lpr.htm<br>
+doc/Use.htm<br>
+doc/VectorDevices.htm<br>
+doc/WhatIsGS.htm<br>
+doc/gs-vms.hlp<br>
+doc/sample_downscale_device.htm<br>
+doc/thirdparty.htm<br>
+man/dvipdf.1<br>
+man/gs.1<br>
+man/gslp.1<br>
+man/gsnd.1<br>
+man/pdf2dsc.1<br>
+man/pdf2ps.1<br>
+man/pf2afm.1<br>
+man/pfbtopfa.1<br>
+man/printafm.1<br>
+man/ps2ascii.1<br>
+man/ps2epsi.1<br>
+man/ps2pdf.1<br>
+man/ps2pdfwr.1<br>
+man/ps2ps.1<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-03-13 10:37:08 +0000
+</strong>
+<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7c9a54209a2758769102361a456353e7e5993821">7c9a54209a2758769102361a456353e7e5993821</a>
+<blockquote>
+<p>
+ Squash a benign compiler warning<br>
+<br>
+devices/vector/gdevpdtt.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-03-13 10:33:52 +0000
+</strong>
+<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=353c6caa4b8dea6baae337b30217139e996e9b94">353c6caa4b8dea6baae337b30217139e996e9b94</a>
+<blockquote>
+<p>
+ pdfwrite - reject inappropriate ICC profiles<br>
+<br>
+ PDF files cannot include the full possible range of ICC profiles, if<br>
+ we encounter one of these (eg from an XPS file) then refuse to embed it<br>
+ and instead return gs_error_rangecheck, so that the calling code will<br>
+ fall back to a device space representation.<br>
+<br>
+ NOTE we currently permit GS_UNDEFINED as a valid data_cs which we really<br>
+ shouldn't but the current code, when converting a CIEBasedDEF or<br>
+ CIEBasedDEFG (possibly other CIE spaces) to ICC creates a profile<br>
+ where data_cs is GS_UNDEFINED (which is 0, so probably not actually<br>
+ filled in).<br>
+<br>
+devices/vector/gdevpdfk.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-03-12 14:22:44 +0000
+</strong>
+<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=23f66c8eec91e8efcbc600d987cf8bde7e3dce4b">23f66c8eec91e8efcbc600d987cf8bde7e3dce4b</a>
+<blockquote>
+<p>
+ pdfwrite - avoid use of /.notdef when converting PCL fonts to type 3<br>
+<br>
+ Bug #699102 &quot;using -sDEVICE=pdfwrite option generate an incorrect code 128 barcode&quot;<br>
+<br>
+ This is actually an Acrobat bug, every other viewer I've tested works as<br>
+ expected, Acrobat does not.<br>
+<br>
+ The problem appears to be related to defining a /.notdef glyph and<br>
+ encoding it at a position other than 0 in the Encoding. If we do that,<br>
+ and use the encoded /.notdef glyph, Acrobat quietly replaces it with the<br>
+ glyph encoded at position 0 in the Encoding of the font.<br>
+<br>
+ Because of the way that PCL fonts work, when we are converting PCL<br>
+ fonts to type 3 PDF fonts, the character (PCL) 0x1D gets assigned the<br>
+ glyph name /.notdef. The actual Encoding of the glyph is at position<br>
+ 0x1D however, which causes Acrobat to substitute the glyph at Encoding<br>
+ position 0.<br>
+<br>
+ This is obviously wrong. However, since its Acrobat, here we add yet<br>
+ another heuristic to avoid defining glyphs with the name /.notdef when<br>
+ creating type 3 PDF fonts from PCL fonts.<br>
+<br>
+ No differences expected<br>
+<br>
+devices/vector/gdevpdtt.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-03-08 13:21:54 +0000
+</strong>
+<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1567dba0b505a0bb816e7b2e34f3915165a7d5b3">1567dba0b505a0bb816e7b2e34f3915165a7d5b3</a>
+<blockquote>
+<p>
+ Avoid total image dropout in interplated rescales.<br>
+<br>
+ Tests show that the following command causes images to disappear:<br>
+<br>
+ gxps -o out.ppm -sDEVICE=ppmraw -72 tests_private/xps/xpsfts-a4/fts_27xx.xps<br>
+<br>
+ This is because we scale a 1600 wide image down to 27 pixels across.<br>
+ As such the weights for each individual pixel round to zero, and we<br>
+ get nothing displayed.<br>
+<br>
+ Adjust for this by still calculating weights as doubles, and carrying<br>
+ the error across the line. This keeps the total sum of the differences<br>
+ correct.<br>
+<br>
+base/siscale.c<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-03-07 14:40:21 +0000
+</strong>
+<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7a6acdfce9344574638c2553f605d86f801f7393">7a6acdfce9344574638c2553f605d86f801f7393</a>
+<blockquote>
+<p>
+ News and Changelog for 9.23 rc1<br>
+<br>
+doc/History9.htm<br>
+doc/News.htm<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-03-07 12:19:48 +0000
+</strong>
+<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c6285cdd7ae7b1c97ffcf0c824234659b03d6d6a">c6285cdd7ae7b1c97ffcf0c824234659b03d6d6a</a>
+<blockquote>
+<p>
+ Dates and versions for 9.23 rc1<br>
+<br>
+doc/API.htm<br>
+doc/C-style.htm<br>
+doc/Commprod.htm<br>
+doc/DLL.htm<br>
+doc/Deprecated.htm<br>
+doc/Details8.htm<br>
+doc/Details9.htm<br>
+doc/Develop.htm<br>
+doc/Devices.htm<br>
+doc/Drivers.htm<br>
+doc/Fonts.htm<br>
+doc/Helpers.htm<br>
+doc/History1.htm<br>
+doc/History2.htm<br>
+doc/History3.htm<br>
+doc/History4.htm<br>
+doc/History5.htm<br>
+doc/History6.htm<br>
+doc/History7.htm<br>
+doc/History8.htm<br>
+doc/History9.htm<br>
+doc/Install.htm<br>
+doc/Issues.htm<br>
+doc/Language.htm<br>
+doc/Lib.htm<br>
+doc/Make.htm<br>
+doc/News.htm<br>
+doc/Projects.htm<br>
+doc/Ps-style.htm<br>
+doc/Ps2epsi.htm<br>
+doc/Psfiles.htm<br>
+doc/Readme.htm<br>
+doc/Release.htm<br>
+doc/SavedPages.htm<br>
+doc/Source.htm<br>
+doc/Unix-lpr.htm<br>
+doc/Use.htm<br>
+doc/VectorDevices.htm<br>
+doc/WhatIsGS.htm<br>
+doc/gs-vms.hlp<br>
+doc/sample_downscale_device.htm<br>
+doc/thirdparty.htm<br>
+man/dvipdf.1<br>
+man/gs.1<br>
+man/gslp.1<br>
+man/gsnd.1<br>
+man/pdf2dsc.1<br>
+man/pdf2ps.1<br>
+man/pf2afm.1<br>
+man/pfbtopfa.1<br>
+man/printafm.1<br>
+man/ps2ascii.1<br>
+man/ps2epsi.1<br>
+man/ps2pdf.1<br>
+man/ps2pdfwr.1<br>
+man/ps2ps.1<br>
+<p>
+</blockquote>
+<hr>
+<p><strong>2018-03-07 09:59:55 +0000
+</strong>
+<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
+<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0df45c3d11246d773110d5b1a563d7462f3acac1">0df45c3d11246d773110d5b1a563d7462f3acac1</a>
+<blockquote>
+<p>
+ Revision date and product for release candidate<br>
+<br>
+base/gscdef.c<br>
+base/version.mak<br>
+<p>
+</blockquote>
+<hr>
+<hr size=20>
+<h3><a name="9.23_changelog"></a>Changelog</h3>
<p><strong>2018-03-21 08:41:35 +0000
</strong>
<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
@@ -178571,7 +188460,7 @@ or contact Artifex Software, Inc., 1305 Grant Avenue - Suite 200,
Novato, CA 94945, U.S.A., +1(415)492-9861, for further information.
<p>
-<small>Ghostscript version 9.23, 21 March 2018
+<small>Ghostscript version 9.24, 28 August 2018
<!-- [3.0 end visible trailer] ============================================= -->
diff --git a/doc/Install.htm b/doc/Install.htm
index 827b17392..1a6e2c620 100644
--- a/doc/Install.htm
+++ b/doc/Install.htm
@@ -441,7 +441,7 @@ or contact Artifex Software, Inc., 1305 Grant Avenue - Suite 200,
Novato, CA 94945, U.S.A., +1(415)492-9861, for further information.
<p>
-<small>Ghostscript version 9.23, 21 March 2018
+<small>Ghostscript version 9.24, 28 August 2018
<!-- [3.0 end visible trailer] ============================================= -->
diff --git a/doc/Language.htm b/doc/Language.htm
index 6c7e3eee0..dd375a59b 100644
--- a/doc/Language.htm
+++ b/doc/Language.htm
@@ -1906,7 +1906,7 @@ or contact Artifex Software, Inc., 1305 Grant Avenue - Suite 200,
Novato, CA 94945, U.S.A., +1(415)492-9861, for further information.
<p>
-<small>Ghostscript version 9.23, 21 March 2018
+<small>Ghostscript version 9.24, 28 August 2018
<!-- [3.0 end visible trailer] ============================================= -->
diff --git a/doc/Lib.htm b/doc/Lib.htm
index 938386273..557574426 100644
--- a/doc/Lib.htm
+++ b/doc/Lib.htm
@@ -1048,7 +1048,7 @@ or contact Artifex Software, Inc., 1305 Grant Avenue - Suite 200,
Novato, CA 94945, U.S.A., +1(415)492-9861, for further information.
<p>
-<small>Ghostscript version 9.23, 21 March 2018
+<small>Ghostscript version 9.24, 28 August 2018
<!-- [3.0 end visible trailer] ============================================= -->
diff --git a/doc/Make.htm b/doc/Make.htm
index b328e4772..48ca11f36 100644
--- a/doc/Make.htm
+++ b/doc/Make.htm
@@ -1511,7 +1511,7 @@ or contact Artifex Software, Inc., 1305 Grant Avenue - Suite 200,
Novato, CA 94945, U.S.A., +1(415)492-9861, for further information.
<p>
-<small>Ghostscript version 9.23, 21 March 2018
+<small>Ghostscript version 9.24, 28 August 2018
<!-- [3.0 end visible trailer] ============================================= -->
diff --git a/doc/News.htm b/doc/News.htm
index 0c7b94e62..ccc9bfb30 100644
--- a/doc/News.htm
+++ b/doc/News.htm
@@ -97,7 +97,7 @@ overview</a>.
<!-- [2.0 begin contents] ================================================== -->
-<h2><a name="Version9.23"></a>Version 9.23 (2018-03-21)</h2>
+<h2><a name="Version9.23"></a>Version 9.24 (2018-08-28)</h2>
<p>This is the seventeenth full release in the stable 9.x series.
@@ -172,7 +172,7 @@ or contact Artifex Software, Inc., 1305 Grant Avenue - Suite 200,
Novato, CA 94945, U.S.A., +1(415)492-9861, for further information.
<p>
-<small>Ghostscript version 9.23, 21 March 2018
+<small>Ghostscript version 9.24, 28 August 2018
<!-- [3.0 end visible trailer] ============================================= -->
diff --git a/doc/Ps-style.htm b/doc/Ps-style.htm
index 24a52e2b8..bdfe10d6b 100644
--- a/doc/Ps-style.htm
+++ b/doc/Ps-style.htm
@@ -550,7 +550,7 @@ or contact Artifex Software, Inc., 1305 Grant Avenue - Suite 200,
Novato, CA 94945, U.S.A., +1(415)492-9861, for further information.
<p>
-<small>Ghostscript version 9.23, 21 March 2018
+<small>Ghostscript version 9.24, 28 August 2018
<!-- [3.0 end visible trailer] ============================================= -->
diff --git a/doc/Ps2epsi.htm b/doc/Ps2epsi.htm
index e5a2cf8e6..943963c69 100644
--- a/doc/Ps2epsi.htm
+++ b/doc/Ps2epsi.htm
@@ -230,7 +230,7 @@ or contact Artifex Software, Inc., 1305 Grant Avenue - Suite 200,
Novato, CA 94945, U.S.A., +1(415)492-9861, for further information.
<p>
-<small>Ghostscript version 9.23, 21 March 2018
+<small>Ghostscript version 9.24, 28 August 2018
<!-- [3.0 end visible trailer] ============================================= -->
diff --git a/doc/Psfiles.htm b/doc/Psfiles.htm
index 6fe7db81a..4245b3886 100644
--- a/doc/Psfiles.htm
+++ b/doc/Psfiles.htm
@@ -901,7 +901,7 @@ or contact Artifex Software, Inc., 1305 Grant Avenue - Suite 200,
Novato, CA 94945, U.S.A., +1(415)492-9861, for further information.
<p>
-<small>Ghostscript version 9.23, 21 March 2018
+<small>Ghostscript version 9.24, 28 August 2018
<!-- [3.0 end visible trailer] ============================================= -->
diff --git a/doc/Readme.htm b/doc/Readme.htm
index 498a8578d..dbea10b07 100644
--- a/doc/Readme.htm
+++ b/doc/Readme.htm
@@ -573,7 +573,7 @@ or contact Artifex Software, Inc., 1305 Grant Avenue - Suite 200,
Novato, CA 94945, U.S.A., +1(415)492-9861, for further information.
<p>
-<small>Ghostscript version 9.23, 21 March 2018
+<small>Ghostscript version 9.24, 28 August 2018
<!-- [3.0 end visible trailer] ============================================= -->
diff --git a/doc/Release.htm b/doc/Release.htm
index 21ad7d6ac..d648f0aab 100644
--- a/doc/Release.htm
+++ b/doc/Release.htm
@@ -846,7 +846,7 @@ or contact Artifex Software, Inc., 1305 Grant Avenue - Suite 200,
Novato, CA 94945, U.S.A., +1(415)492-9861, for further information.
<p>
-<small>Ghostscript version 9.23, 21 March 2018
+<small>Ghostscript version 9.24, 28 August 2018
<!-- [3.0 end visible trailer] ============================================= -->
diff --git a/doc/SavedPages.htm b/doc/SavedPages.htm
index 59a36dc3b..8109bfdfd 100644
--- a/doc/SavedPages.htm
+++ b/doc/SavedPages.htm
@@ -317,7 +317,7 @@ or contact Artifex Software, Inc., 1305 Grant Avenue - Suite 200,
Novato, CA 94945, U.S.A., +1(415)492-9861.
<p>
-<small>Ghostscript version 9.23, 21 March 2018
+<small>Ghostscript version 9.24, 28 August 2018
<!-- [3.0 end visible trailer] ============================================= -->
diff --git a/doc/Source.htm b/doc/Source.htm
index 97eaf697e..eae4137bd 100644
--- a/doc/Source.htm
+++ b/doc/Source.htm
@@ -471,7 +471,7 @@ or contact Artifex Software, Inc., 1305 Grant Avenue - Suite 200,
Novato, CA 94945, U.S.A., +1(415)492-9861, for further information.
<p>
-<small>Ghostscript version 9.23, 21 March 2018
+<small>Ghostscript version 9.24, 28 August 2018
<!-- [3.0 end visible trailer] ============================================= -->
diff --git a/doc/Unix-lpr.htm b/doc/Unix-lpr.htm
index dc176e5a6..930e6cf4a 100644
--- a/doc/Unix-lpr.htm
+++ b/doc/Unix-lpr.htm
@@ -305,7 +305,7 @@ or contact Artifex Software, Inc., 1305 Grant Avenue - Suite 200,
Novato, CA 94945, U.S.A., +1(415)492-9861, for further information.
<p>
-<small>Ghostscript version 9.23, 21 March 2018
+<small>Ghostscript version 9.24, 28 August 2018
<!-- [3.0 end visible trailer] ============================================= -->
diff --git a/doc/Use.htm b/doc/Use.htm
index a73adffdf..9c5c448fb 100644
--- a/doc/Use.htm
+++ b/doc/Use.htm
@@ -5093,7 +5093,7 @@ or contact Artifex Software, Inc., 1305 Grant Avenue - Suite 200,
Novato, CA 94945, U.S.A., +1(415)492-9861, for further information.
<p>
-<small>Ghostscript version 9.23, 21 March 2018
+<small>Ghostscript version 9.24, 28 August 2018
<!-- [3.0 end visible trailer] ============================================= -->
diff --git a/doc/VectorDevices.htm b/doc/VectorDevices.htm
index e6bdd3f87..7f3e5d6b1 100644
--- a/doc/VectorDevices.htm
+++ b/doc/VectorDevices.htm
@@ -1396,7 +1396,7 @@ or contact Artifex Software, Inc., 1305 Grant Avenue - Suite 200,
Novato, CA 94945, U.S.A., +1(415)492-9861, for further information.
<p>
-<small>Ghostscript version 9.23, 21 March 2018
+<small>Ghostscript version 9.24, 28 August 2018
<!-- [3.0 end visible trailer] ============================================= -->
diff --git a/doc/WhatIsGS.htm b/doc/WhatIsGS.htm
index e86191a4e..a782d6eb4 100644
--- a/doc/WhatIsGS.htm
+++ b/doc/WhatIsGS.htm
@@ -190,7 +190,7 @@ or contact Artifex Software, Inc., 1305 Grant Avenue - Suite 200,
Novato, CA 94945, U.S.A., +1(415)492-9861, for further information.
<p>
-<small>Ghostscript version 9.23, 21 March 2018
+<small>Ghostscript version 9.24, 28 August 2018
<!-- [3.0 end visible trailer] ============================================= -->
diff --git a/doc/gs-vms.hlp b/doc/gs-vms.hlp
index f71dd0c38..3dfd7fd43 100644
--- a/doc/gs-vms.hlp
+++ b/doc/gs-vms.hlp
@@ -1,6 +1,6 @@
1 gs
gs - GPL Ghostscript interpreter/previewer
-! Ghostscript version 9.23, 21 March 2018
+! Ghostscript version 9.24, 28 August 2018
Usage:
$ gs [options] [file ...]
diff --git a/doc/sample_downscale_device.htm b/doc/sample_downscale_device.htm
index be62c9630..fea5150bb 100644
--- a/doc/sample_downscale_device.htm
+++ b/doc/sample_downscale_device.htm
@@ -264,7 +264,7 @@ or contact Artifex Software, Inc., 1305 Grant Avenue - Suite 200,
Novato, CA 94945, U.S.A., +1(415)492-9861, for further information.
<p>
-<small>Ghostscript version 9.23, 21 March 2018
+<small>Ghostscript version 9.24, 28 August 2018
<!-- [3.0 end visible trailer] ============================================= -->
<!--FINISH EDITING HERE-->
diff --git a/doc/subclass.htm b/doc/subclass.htm
index a6913a85e..fdd0fc439 100644
--- a/doc/subclass.htm
+++ b/doc/subclass.htm
@@ -813,7 +813,7 @@ or contact Artifex Software, Inc., 1305 Grant Avenue - Suite 200,
Novato, CA 94945, U.S.A., +1(415)492-9861.
<p>
-<small>Ghostscript version 9.23, 21 March 2018
+<small>Ghostscript version 9.24, 28 August 2018
<!-- [3.0 end visible trailer] ============================================= -->
diff --git a/doc/thirdparty.htm b/doc/thirdparty.htm
index 17dcbed06..2315099f3 100644
--- a/doc/thirdparty.htm
+++ b/doc/thirdparty.htm
@@ -269,7 +269,7 @@ or contact Artifex Software, Inc., 1305 Grant Avenue - Suite 200,
Novato, CA 94945, U.S.A., +1(415)492-9861, for further information.
<p>
-<small>Ghostscript version 9.23, 21 March 2018
+<small>Ghostscript version 9.24, 28 August 2018
<!-- [3.0 end visible trailer] ============================================= -->
diff --git a/man/dvipdf.1 b/man/dvipdf.1
index e2539427b..ffb477b55 100644
--- a/man/dvipdf.1
+++ b/man/dvipdf.1
@@ -1,4 +1,4 @@
-.TH DVIPDF 1 "21 March 2018" 9.23 Ghostscript \" -*- nroff -*-
+.TH DVIPDF 1 "28 August 2018" 9.24 Ghostscript \" -*- nroff -*-
.SH NAME
dvipdf \- Convert TeX DVI file to PDF using ghostscript and dvips
.SH SYNOPSIS
@@ -21,7 +21,7 @@ and any options from the command-line.
.SH SEE ALSO
gs(1), dvips(1)
.SH VERSION
-This document was last revised for Ghostscript version 9.23.
+This document was last revised for Ghostscript version 9.24.
.SH AUTHOR
Artifex Software, Inc. are the
primary maintainers of Ghostscript.
diff --git a/man/gs.1 b/man/gs.1
index d9a624ce0..18cbd29e0 100644
--- a/man/gs.1
+++ b/man/gs.1
@@ -1,4 +1,4 @@
-.TH GS 1 "21 March 2018" 9.23 Ghostscript \" -*- nroff -*-
+.TH GS 1 "28 August 2018" 9.24 Ghostscript \" -*- nroff -*-
.SH NAME
gs \- Ghostscript (PostScript and PDF language interpreter and previewer)
.SH SYNOPSIS
@@ -442,7 +442,7 @@ The various Ghostscript document files (above), especially \fBUse.htm\fR.
See http://bugs.ghostscript.com/ and the Usenet news group
comp.lang.postscript.
.SH VERSION
-This document was last revised for Ghostscript version 9.23.
+This document was last revised for Ghostscript version 9.24.
.SH AUTHOR
Artifex Software, Inc. are the primary maintainers
of Ghostscript.
diff --git a/man/gslp.1 b/man/gslp.1
index 1b3425af3..1d7cc4803 100644
--- a/man/gslp.1
+++ b/man/gslp.1
@@ -1,4 +1,4 @@
-.TH GSLP 1 "21 March 2018" 9.23 Ghostscript \" -*- nroff -*-
+.TH GSLP 1 "28 August 2018" 9.24 Ghostscript \" -*- nroff -*-
.SH NAME
gslp \- Format and print text using ghostscript
.br
@@ -92,7 +92,7 @@ Also, the string %# in a heading or footing is replaced with the page #.
.SH SEE ALSO
gs(1)
.SH VERSION
-This document was last revised for Ghostscript version 9.23.
+This document was last revised for Ghostscript version 9.24.
.SH AUTHOR
Artifex Software, Inc. are the
primary maintainers of Ghostscript.
diff --git a/man/gsnd.1 b/man/gsnd.1
index 88ca4276e..4915395e5 100644
--- a/man/gsnd.1
+++ b/man/gsnd.1
@@ -1,4 +1,4 @@
-.TH GSND 1 "21 March 2018" 9.23 Ghostscript \" -*- nroff -*-
+.TH GSND 1 "28 August 2018" 9.24 Ghostscript \" -*- nroff -*-
.SH NAME
gsnd \- Run ghostscript (PostScript and PDF engine) without display
.SH SYNOPSIS
@@ -12,7 +12,7 @@ flag, followed by any other arguments from the command-line.
.SH SEE ALSO
gs(1)
.SH VERSION
-This document was last revised for Ghostscript version 9.23.
+This document was last revised for Ghostscript version 9.24.
.SH AUTHOR
Artifex Software, Inc. are the
primary maintainers of Ghostscript.
diff --git a/man/pdf2dsc.1 b/man/pdf2dsc.1
index b37bd6a93..c8de0b3ea 100644
--- a/man/pdf2dsc.1
+++ b/man/pdf2dsc.1
@@ -1,4 +1,4 @@
-.TH PDF2DSC 1 "21 March 2018" 9.23 "Ghostscript Tools" \" -*- nroff -*-
+.TH PDF2DSC 1 "28 August 2018" 9.24 "Ghostscript Tools" \" -*- nroff -*-
.SH NAME
pdf2dsc \- generate a PostScript page list of a PDF document
.SH SYNOPSIS
@@ -28,6 +28,6 @@ Ghostscript since release 3.53.
.SH SEE ALSO
gs(1), ghostview(1)
.SH VERSION
-This document was last revised for Ghostscript version 9.23.
+This document was last revised for Ghostscript version 9.24.
.SH AUTHOR
Yves Arrouye <yves.arrouye@usa.net> and Russell Lang gsview at ghostgum.com.au
diff --git a/man/pdf2ps.1 b/man/pdf2ps.1
index 2adb278d4..896f67a25 100644
--- a/man/pdf2ps.1
+++ b/man/pdf2ps.1
@@ -1,4 +1,4 @@
-.TH PDF2PS 1 "21 March 2018" 9.23 "Ghostscript Tools" \" -*- nroff -*-
+.TH PDF2PS 1 "28 August 2018" 9.24 "Ghostscript Tools" \" -*- nroff -*-
.SH NAME
pdf2ps \- Ghostscript PDF to PostScript translator
.SH SYNOPSIS
@@ -14,7 +14,7 @@ LanguageLevel 3 in the output.
Run "\fBgs -h\fR" to find the location of Ghostscript documentation on your
system, from which you can get more details.
.SH VERSION
-This document was last revised for Ghostscript version 9.23.
+This document was last revised for Ghostscript version 9.24.
.SH AUTHOR
Artifex Software, Inc. are the
primary maintainers of Ghostscript.
diff --git a/man/pf2afm.1 b/man/pf2afm.1
index 03b83c901..b4101e51c 100644
--- a/man/pf2afm.1
+++ b/man/pf2afm.1
@@ -1,4 +1,4 @@
-.TH PF2AFM 1 "21 March 2018" 9.23 Ghostscript \" -*- nroff -*-
+.TH PF2AFM 1 "28 August 2018" 9.24 Ghostscript \" -*- nroff -*-
.SH NAME
pf2afm \- Make an AFM file from Postscript (PFB/PFA/PFM) font files using ghostscript
.SH SYNOPSIS
@@ -15,7 +15,7 @@ gs(1)
.br
pf2afm.ps in the Ghostscript lib directory.
.SH VERSION
-This document was last revised for Ghostscript version 9.23.
+This document was last revised for Ghostscript version 9.24.
.SH AUTHOR
Artifex Software, Inc. are the
primary maintainers of Ghostscript.
diff --git a/man/pfbtopfa.1 b/man/pfbtopfa.1
index 6121d7309..9ab34dc6b 100644
--- a/man/pfbtopfa.1
+++ b/man/pfbtopfa.1
@@ -1,4 +1,4 @@
-.TH PFBTOPFA 1 "21 March 2018" 9.23 Ghostscript \" -*- nroff -*-
+.TH PFBTOPFA 1 "28 August 2018" 9.24 Ghostscript \" -*- nroff -*-
.SH NAME
pfbtopfa \- Convert Postscript .pfb fonts to .pfa format using ghostscript
.SH SYNOPSIS
@@ -10,7 +10,7 @@ to convert a .pfb file into a .pfa file.
.SH SEE ALSO
gs(1)
.SH VERSION
-This document was last revised for Ghostscript version 9.23.
+This document was last revised for Ghostscript version 9.24.
.SH AUTHOR
Artifex Software, Inc. are the
primary maintainers of Ghostscript.
diff --git a/man/printafm.1 b/man/printafm.1
index d4dbd3533..b51065947 100644
--- a/man/printafm.1
+++ b/man/printafm.1
@@ -1,4 +1,4 @@
-.TH PRINTAFM 1 "21 March 2018" 9.23 Ghostscript \" -*- nroff -*-
+.TH PRINTAFM 1 "28 August 2018" 9.24 Ghostscript \" -*- nroff -*-
.SH NAME
printafm \- Print the metrics from a Postscript font in AFM format using ghostscript
.SH SYNOPSIS
@@ -11,7 +11,7 @@ Output goes to stdout.
.SH SEE ALSO
gs(1)
.SH VERSION
-This document was last revised for Ghostscript version 9.23.
+This document was last revised for Ghostscript version 9.24.
.SH AUTHOR
Artifex Software, Inc. are the
primary maintainers of Ghostscript.
diff --git a/man/ps2ascii.1 b/man/ps2ascii.1
index a781f4bd5..efc649e45 100644
--- a/man/ps2ascii.1
+++ b/man/ps2ascii.1
@@ -1,4 +1,4 @@
-.TH PS2ASCII 1 "21 March 2018" 9.23 "Ghostscript Tools" \" -*- nroff -*-
+.TH PS2ASCII 1 "28 August 2018" 9.24 "Ghostscript Tools" \" -*- nroff -*-
.SH NAME
ps2ascii \- Ghostscript translator from PostScript or PDF to ASCII
.SH SYNOPSIS
@@ -22,7 +22,7 @@ system, from which you can get more details.
.SH SEE ALSO
pstotext(1), http://www.research.digital.com/SRC/virtualpaper/pstotext.html
.SH VERSION
-This document was last revised for Ghostscript version 9.23.
+This document was last revised for Ghostscript version 9.24.
.SH AUTHOR
Artifex Software, Inc. are the
primary maintainers of Ghostscript.
diff --git a/man/ps2epsi.1 b/man/ps2epsi.1
index acce59478..52d280fbd 100644
--- a/man/ps2epsi.1
+++ b/man/ps2epsi.1
@@ -1,4 +1,4 @@
-.TH PS2EPSI 1 "21 March 2018" 9.23 "Ghostscript Tools" \" -*- nroff -*-
+.TH PS2EPSI 1 "28 August 2018" 9.24 "Ghostscript Tools" \" -*- nroff -*-
.SH NAME
ps2epsi \- generate conforming Encapsulated PostScript
.SH SYNOPSIS
@@ -59,7 +59,7 @@ ps2epsi.ps>the Ghostscript program which does the work
.SH SEE ALSO
gs (1)
.SH VERSION
-This document was last revised for Ghostscript version 9.23.
+This document was last revised for Ghostscript version 9.24.
However, the content may be obsolete, or inconsistent with ps2epsi.txt.
.SH AUTHOR
George Cameron
diff --git a/man/ps2pdf.1 b/man/ps2pdf.1
index 1eba72ee6..97e083784 100644
--- a/man/ps2pdf.1
+++ b/man/ps2pdf.1
@@ -1,4 +1,4 @@
-.TH PS2PDF 1 "21 March 2018" 9.23 Ghostscript \" -*- nroff -*-
+.TH PS2PDF 1 "28 August 2018" 9.24 Ghostscript \" -*- nroff -*-
.SH NAME
ps2pdf \- Convert PostScript to PDF using ghostscript
.br
@@ -89,7 +89,7 @@ Ps2pdf.htm in the Ghostscript documentation
See http://bugs.ghostscript.com/ and the Usenet news group
comp.lang.postscript.
.SH VERSION
-This document was last revised for Ghostscript version 9.23.
+This document was last revised for Ghostscript version 9.24.
.SH AUTHOR
Artifex Software, Inc. are the
primary maintainers of Ghostscript.
diff --git a/man/ps2pdfwr.1 b/man/ps2pdfwr.1
index f36e858b7..d5c22ea79 100644
--- a/man/ps2pdfwr.1
+++ b/man/ps2pdfwr.1
@@ -1,4 +1,4 @@
-.TH PS2PDFWR 1 "21 March 2018" 9.23 Ghostscript \" -*- nroff -*-
+.TH PS2PDFWR 1 "28 August 2018" 9.24 Ghostscript \" -*- nroff -*-
.SH NAME
ps2pdfwr \- Convert PostScript to PDF without specifying CompatibilityLevel, using ghostscript
.SH SYNOPSIS
@@ -23,7 +23,7 @@ scripts all invoke this one with the addition of the respective compatibility le
.SH SEE ALSO
gs(1), ps2pdf(1)
.SH VERSION
-This document was last revised for Ghostscript version 9.23.
+This document was last revised for Ghostscript version 9.24.
.SH AUTHOR
Artifex Software, Inc. are the
primary maintainers of Ghostscript.
diff --git a/man/ps2ps.1 b/man/ps2ps.1
index bb655946c..64447ec4d 100644
--- a/man/ps2ps.1
+++ b/man/ps2ps.1
@@ -1,4 +1,4 @@
-.TH PS2PS 1 "21 March 2018" 9.23 "Ghostscript Tools" \" -*- nroff -*-
+.TH PS2PS 1 "28 August 2018" 9.24 "Ghostscript Tools" \" -*- nroff -*-
.SH NAME
ps2ps, eps2eps \- Ghostscript PostScript "distiller"
.SH SYNOPSIS
@@ -22,7 +22,7 @@ system, from which you can get more details.
.SH SEE ALSO
ps2pdf(1), ps2ascii(1), ps2epsi(1)
.SH VERSION
-This document was last revised for Ghostscript version 9.23.
+This document was last revised for Ghostscript version 9.24.
.SH AUTHOR
Artifex Software, Inc. are the
primary maintainers of Ghostscript.